美文网首页
Math数组Date

Math数组Date

作者: 谨言_慎行 | 来源:发表于2017-07-31 10:42 被阅读0次

    Math任务

    1、写一个函数,返回从min到max之间的 随机整数,包括min不包括max

    function random(a,b) {
        return a + Math.floor(Math.random()*(b-a))
    }
    

    2、写一个函数,返回从min都max之间的 随机整数,包括min包括max

    function random(a,b+1) {
        return a + Math.floor(Math.random()*(b-a))
    }
    

    3、写一个函数,生成一个长度为 n 的随机字符串,字符串字符的取值范围包括0到9,a到 z,A到Z。

    function random(a,b) {
        return a + Math.floor(Math.random()*(b-a))
    }
    function randomStr(n){
        var dict = "0123456789qwertyuiopasdfghjklzxcvbnmQWERTYUIOPASDFGHJKLZXCVBNM"
        var str = ''
        for(i = 0;i < n;i++){
            str += dict[random(0,62)]
        }
        return str
    }
    randomStr(5)
    

    4、写一个函数,生成一个随机 IP 地址,一个合法的 IP 地址为 0.0.0.0~255.255.255.255

    function random(a,b){
        return a + Math.floor(Math.random()*(b-a))
    }
    function randomIP(len){
    var arr = []
    for(i=0;i<4;i++){
        arr.push(random(0,256))
    }
        return arr.join('.')
    }
     randomIP()
    

    5、写一个函数,生成一个随机颜色字符串,合法的颜色为#000000~ #ffffff

    function random(a,b){
        return a + Math.floor(Math.random()*(b-a))
    }
    var dict = "0123456789abcdef"
    function randomC(len){
    var str = ''
    for(i=0;i<6;i++){
        str += dict[random(0,16)]
    }
        return '#'+ str
    }
    randomC()
    

    数组

    1、数组方法里push、pop、shift、unshift、join、splice分别是什么作用?用 splice函数分别实现push、pop、shift、unshift方法

    /*push方法的实现与pop方法的实现(栈方法)*/
    var arr = [3,5,6]
    arr.push(8)// 在数组末尾加上8,会输出数组的长度
    arr.pop()// 拿出数组末尾数,输出数组末尾值
    
    /*shift方法的实现和unshift的实现方法*/
    var arr = [5,8,6]
    arr.shift()// 拿掉数组开始的数字,输出未拿掉数字前的数组长度
    arr.unshift(8)// 在其实位置加上数字,输出添加后的数组长度
    
    /*splice方法用于一次性解决数组添加、删除(这两种方法一结合就可以达到替换效果),方法有三个参数
    1.开始索引
    2.删除元素的位移 
    3.插入的新元素,当然也可以写多个(在索引位置前)
    splice方法返回一个由删除元素组成的新数组,没有删除则返回空数组*/
    var arr = [4,8,6]
    arr.splice(1,0, 25, 56)
    console.log(arr)//[4,25,56,8,6]
    /*join('')将数组链接成字符串*/
    var arr = [5,4,6]
    arr.join('-')//"5-4-6"
    

    用 splice函数分别实现push、pop、shift、unshift方法

    var arr = [5,6,8]
    arr.splice(3,0, 9)// 用splice实现push 起始位置为arr.length
    
    var arr = [5,6,8]
    arr.splice(2,1)//实现pop  起始位置为arr.length-1,删除元素位移为1
    
    var arr = [5,6,8]
    arr.splice(0,1)//实现shift  起始位置为0,删除元素位移为1
    
    var arr = [5,6,8]
    arr.splice(0,0, 4)//实现unshift  起始位置为0,删除元素位移为0,添加内容
    

    2、写一个函数,操作数组,数组中的每一项变为原来的平方,在原数组上操作

    function squareArr(arr){
        for(var i = 0;i < arr.length;i++){
            arr[i] = arr[i] * arr[i]
        }return arr[i]
    }
    var arr = [2, 4, 6]
    squareArr(arr)
    console.log(arr)
    

    3、写一个函数,操作数组,返回一个新数组,新数组中只包含正数,原数组不变

    function filterPositive(arr) {
        var newArr = []
        var j = 0
        for(var i = 0;i < arr.length;i++) {
            if(typeof arr[i] === "number" && arr[i] > 0){
                newArr[j] = arr[i]
                j++
            }
        }return newArr
    }
    var arr = [3, -1,  2,  '饥人谷', true]
    var newArr = filterPositive(arr)
    console.log(newArr) 
    console.log(arr)
    

    Date 任务

    1、 写一个函数getChIntv,获取从当前时间到指定日期的间隔时间

    function getCHIntv(dateStr){        
        var targetDate = new Date(dateStr)
        var curDate = new Date()
        var offset = Math.abs(targetDate - curDate)
    
        var totalSeconds = Math.floor(offset/1000)
        var senond = totalSeconds%60
        var totalMins = Math.floor(totalSeconds/60)
        var min = totalMins%60
        var totalHours = Math.floor(totalMins/60)
        var hour = totalHours%24
        var day = Math.floor(totalHours/24)
    
        return day + '天' + hour + '小时' + min + '分钟' + senond + '秒'
    }
       getCHIntv('2017-8-23')
    

    2、把hh-mm-dd格式数字日期改成中文日期

    function getChsDate(date){
        var dict = ['零','一','二','三','四','五','六','七','八','九','十','十一','十二','十三','十四','十五','十六','十七','十八','十九','二十','二十一','二十二','二十三','二十四','二十五','二十六','二十七','二十八','二十九','三十','三十一']
        var arr = []
        var newArr = date.split('-')
        var year = newArr[0]
        for(var i = 0; i < year.length; i++){
            arr.push(dict[year[i]])
        }
        arr.push("年")
        arr.push(dict[parseInt(newArr[1],10)])
        arr.push("月")
        arr.push(dict[parseInt(newArr[2],10)])
        arr.push("日")
        var newArr = arr.join('')
        return newArr
    }
    var str = getChsDate('2015-01-08');
    console.log(str);
    

    3、写一个函数,参数为时间对象毫秒数的字符串格式,返回值为字符串。假设参数为时间对象毫秒数t,根据t的时间分别返回如下字符串:

    • 刚刚( t 距当前时间不到1分钟时间间隔)
    • 3分钟前 (t距当前时间大于等于1分钟,小于1小时)
    • 8小时前 (t 距离当前时间大于等于1小时,小于24小时)
    • 3天前 (t 距离当前时间大于等于24小时,小于30天)
    • 2个月前 (t 距离当前时间大于等于30天小于12个月)
    • 8年前 (t 距离当前时间大于等于12个月)
    function friendlyDate(time){
        var friendlyDate = time
        var curDate = new Date().getTime()
        var offset = curDate - friendlyDate
        if(offset < 60000){
            return '刚刚'
        }else if(offset < 3600000){
            return '3分钟前'
        }else if(offset < 3600000*24){
            return '8小时前'
        }else if(offset < 3600000*24*30){
            return '3天前'
        }else if(offset < 3600000*24*30*12){
            return '2个月前'
        }else if(offset >= 3600000*24*30*12){
            return '8年前'
        }
    }
        var str = friendlyDate( '1485584391984' ) 
        console.log(str)
        var str2 = friendlyDate('1405504991984') 
        console.log(str2)
    

    相关文章

      网友评论

          本文标题:Math数组Date

          本文链接:https://www.haomeiwen.com/subject/xfjllxtx.html