美文网首页
Math Array Date

Math Array Date

作者: cross_王 | 来源:发表于2017-07-21 19:34 被阅读0次

    Math

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

    function random (min,max) {
        return Math.floor(min + Math.random()*(max-min));
    }
    console.log(random(1,10));
    

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

    function random (min,max) {
        return Math.floor(min + Math.random()*(max + 1 - min));
    }
    console.log(random(1,10));
    

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

    function getRandStr(len){
      var s = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
      var result='';
      for(var i = 0;i < len;i++){
        result +=s[Math.floor(Math.random()*(s.length))];
      }
      return result;
    }
    var str = getRandStr(10); // 0a3iJiRZap
    

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

    function getRandIP(){
        var array=[];
        for(var i = 0;i < 4;i++){
            array.push(Math.floor(Math.random()*256))
        }
        return array.join('.');
      //补全
    }
    var ip = getRandIP()
    console.log(ip) // 10.234.121.45
    
    

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

    function getRandColor(){
        var s = '0123456789abcdef';
        var result = '';
        for(var i = 0;i < 6;i++){
            result += s[Math.floor(Math.random()*s.length)]
        }
        return '#' + result;
    }
    var color = getRandColor()
    console.log(color)   // #3e2f1b
    

    Array

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

    • push()是向数组后面添加元素,返回添加后数组的长度
    • pop()是删除数组最后一位,返回被删除的值
    • shift()是删除数组第一位,返回被删除的值
    • unshift()是向数组前面添加元素,返回添加后数组的长度
    • splice()模仿push():arr.splice(arr.length,0,value)
    • splice()模仿pop():arr.splice(arr.length-1,1)
    • splice()模仿shift():arr.splice(0,1)
    • splice()模仿unshift():arr.splice(0,0,value)

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

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

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

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

    Date

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

    function getChIntv (str) {
        var curTime = new Date();
        var tarTime = new Date(str);
        var offset = tarTime-curTime;
        console.log(offset);
        //得到秒数
        var totalSceond = Math.floor(offset/1000);
        var sceond = Math.floor(totalSceond%60);
        var minutes = Math.floor(totalSceond/60)%60;
        var hours = Math.floor(totalSceond/60/60)%24;
        var day = Math.floor(totalSceond/60/60/24);
        return '距离国庆节还有' + day + '天' + hours + '小时' + minutes + '分钟' + sceond + '秒';
    }
    var str = getChIntv("2017-10-01 00:00:00");
    console.log(str); 
    
    

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

    function getChsDate (str) {
        var dect = ['零','一','二','三','四','五','六','七','八','九'];
        var year = '';
        var mouth = '';
        var day = '';
        
        var dateArr = str.split('-')
        //年
        for(var i = 0;i<dateArr[0].length;i++){
            year += dect[Number(dateArr[0][i])];
        }
        //月
        if(Number(dateArr[1]) > 10){
            mouth = '十' + dect[Number(dateArr[1][1])];
        }else if(Number(dateArr[1]) == 10) {
            mouth = '十'
        }else{
            mouth = dect[Number(dateArr[1][1])]
        }
        //日
        if(Number(dateArr[2]) > 20){
            day = dect[Number(dateArr[2][0])] + '十' + dect[Number(dateArr[2][1])];
        }else if(Number(dateArr[2]) > 10){
            day = '十' + dect[Number(dateArr[2][1])];
        }else if(Number(dateArr[2]) == 10) {
            day = '十'
        }else{
            day = dect[Number(dateArr[2][1])]
        }
        
        return year+'年'+mouth+'月'+day+'日';
    }
    
    var str = getChsDate('2015-11-02');
    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 now = Date.now();
        var offset = now - time;
        
        if (offset<1*60*1000) {
            return '刚刚';
        } else if(offset<3*60*1000){
            return '3分钟前'
        } else if(offset<8*60*60*1000){
            return '8小时前'
        } else if(offset<3*24*60*60*1000){
            return '3天前'
        } else if(offset<2*30*24*60*60*1000){
            return '两个月前'
        } else if(offset<12*30*24*60*60*1000){
            return '一年前'
        }
    }
    var time1 = new Date('2017-7-24 12:30:12');
    var str = friendlyDate(time1);
    console.log(str);
    

    相关文章

      网友评论

          本文标题:Math Array Date

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