美文网首页
进阶任务-6

进阶任务-6

作者: 小羊熊 | 来源:发表于2017-07-23 17:27 被阅读13次

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

    function random(min,max){
        return min+Math.floor(Math.random()*(max-min))
    }
    

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

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

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

    function random(min,max){
        return min+Math.floor(Math.random()*(max-min))
    }
    function randomStr(length){
    var  dict='0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
      var str = ''
        for(var i =0;i<length;i++){
            // str += random(0,dict.length)
            //将字典看作数组,随机字典的下标,放进空字符串中进行拼接,就能得到想要的东西
            str += dict[random(0,dict.length)]
        }
        return str
        }
    console.clear()
    console.log(randomStr(8))
    
    
    

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

    function random(min,max){
        return min+Math.floor(Math.random()*(max-min))
    }
    function randomIP(){
      // var    dict='0123456789'
      var arr = []
        var str = ''
        for(var i =0;i<4;i++){
    //要包含255,所以要随机到256
            arr.push(random(0,256))
        }
        str = arr.join(',')
        return str
    }
    console.clear()
    console.log(randomIP())
    
    

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

    function random(min,max){
        return min+Math.floor(Math.random()*(max-min))
    }
    function randomColor(){
      var   dict='0123456789abcdef'
      var str = []
        var newColor = ''
        for(var i =0;i<6;i++){
            str.push(dict[random(0,dict.length)])
        }
        str.unshift('#')
            newColor = str.join('') 
        return newColor
    }
    console.clear()
    console.log(randomColor())
    

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

    
    //push()方法:在数组的尾部添加新的元素  该方法直接在原数组操作
    var arr = ['a','f','r','y']
    arr.push(100,88,98)
    console.clear()
    console.log(arr)//a,f,r,y,100,88,98
    
    //pop()方法:从数组的尾巴开始删除数组的最后一个元素 该方法直接在原数组操作
    var arr = ['a','f','r','y']
    arr.push(100,88,98)
    console.clear()
    console.log(arr.pop())//98
    
    //shift()方法:从数组的头部开始删除下标为1的元素 该方法直接在原数组操作
    var arr = ['a','f','r','y']
    console.clear()
    console.log(arr.shift())//返回为 a 
    
    //unshift()方法:�从数组的头部添加元素  该方法直接在原数组操作
    var arr = ['a','f','r','y']
    arr.unshift(4,5,5,5)
    console.clear()
    console.log(arr)//返回为 4,5,5,5,a,f,r,y 
    
    //join()方法:将数组转化成字符串的类型  该方法会生成新的字符串,不会对使用该方法的数组造成影响
    var arr = ['a','f','r','y']
    // 小括号里面什么也不写的话就是元素与元素间没有任何间隔符号
    var str = arr.join('~')
    console.clear()
    console.log(arr)//返回为a,f,r,y 
    console.log(str)//返回为a~f~r~y 
    
    //splice()方法:数组中的万能方法小括号里面能有3个参数 第一个参数就是 开始位置的下标,第二个参数是删除的位移,也就是说删除几个,第三个是要插入数组的新的元素 可以写多个 插入新元素的位置就是从第一个参数的位置依次排开
    var arr = ['a','f','r','y']
    arr.splice(1,1,99,44,67)
    console.clear()
    console.log(arr)//a,99,44,67,r,y 
    
    //--------------------splice()方法全功能展示------------------------------------
    //实现push
    var arr = ['a','f','r','y']
    arr.splice(arr.length,0,78,45,44)
    console.clear()
    console.log(arr)//a,f,r,y,78,45,44 
    
    //实现pop
    var arr = ['a','f','r','y']
    arr.splice(arr.length-1,1)
    console.clear()
    console.log(arr)//a,f,r 
    
    //实现shift
    var arr = ['a','f','r','y']
    arr.splice(0,1)
    console.clear()
    console.log(arr)//f,r,y 
    
    //实现unshift
    var arr = ['a','f','r','y']
    arr.splice(0,0,98,23,23,43)
    console.clear()
    console.log(arr)//98,23,23,43,a,f,r,y 
    
    

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

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

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

    
    ------------------------常规-------------------------
    var arr = [3, -1,  2,  '饥人谷', true]
    function filterPositive(arr){
        var newArr = []
        for(var i = 0;i<arr.length;i++){
            if(typeof arr[i] === 'number'&&arr[i]>0){
                newArr.push(arr[i])
            }
        }
        return newArr
    }
    
    var newArr = filterPositive(arr)
    
    console.clear() 
    console.log(newArr)// [3, 2]
    console.log(arr)// [3, -1,  2,  '饥人谷', true]
    
    ------------------------es5扩展-----------------
    
    var arr = [3, -1,  2,  '饥人谷', true]
    var newArr =  arr.filter(function(value){
      if(typeof value === 'number'&&value>0){
            return arr
        }
        
    })
    console.log(newArr)//3,2
    console.log(arr)//3,-1,2,饥人谷,true 
    
    

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

    function getChIntv(dateStr){
    //将投入到参数的时间(要求的目标时间)进行实例化
        var targetDate = new Date(dateStr)
    // 将现在的时间进行实力化
        var curDate = new Date()
    // 相差时间位移 有可能正值也有可能是负值,所以要用abs方法,返回一个毫秒数
        var offSet = Math.abs(curDate-targetDate)
    
        //将得到的毫秒数 算一下看看一共是多少秒
        var totalSeconds = Math.floor(offSet/1000)
            var second = totalSeconds % 60
        
            var totalMinutes = Math.floor(offSet/1000/60)
        var minutes = totalMinutes % 60
        
        var totalHours = Math.floor(totalMinutes/60)
        var hours = totalHours % 24
        
        var totalDays = Math.floor(totalHours/24)
        var days = totalDays % 24
        
        return days+'天'+hours+'小时'+minutes+'分钟'+second+'秒'
        }
    getChIntv(2017-06-06)//"18天6小时55分钟21秒"
    
    

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

    function getChsDate(dateStr) {
            var dict = ["零","一","二","三","四","五","六","七","八","九","十","十一","十二","十三","十四","十五","十六","十七","十八","十九","二十","二十一","二十二","二十三","二十四","二十五","二十六","二十七","二十八","二十九","三十","三十一"]
    //参数格式一般就是这样的yyyy-mm-dd
    //以分隔符 - 为准 切割获得的参数,切完之后就变成数组了yyyy,mm,dd
            var time = dateStr.split('-');
    //  这方法用完就是把年份给分割了变成了y,y,y,y
            var year = time[0].split('');
    // 通过下标获取到月份
            var month = time[1];
    //通过下标获取到天数
            var day = time[2];
    //拼接新的年份 这一步超级重要!!!    
        var newYear = dict[year[0]]+dict[year[1]]+dict[year[2]]+dict[year[3]];       
    // 下面的思路就和拼接年份的思路一样了 不过参数可能是0x所以要先转换成整数
        var newMonth = dict[parseInt(month)];       
        var newDay = dict[parseInt(day)];
    // 最后拼接字符串
        return newYear+"年"+newMonth+"月"+newDay+"日";
    }
        
    var str = getChsDate('2017-01-08');
    console.log(str);  // 二零一七年一月八日 
    
    

    写一个函数,参数为时间对象毫秒数的字符串格式,返回值为字符串。假设参数为时间对象毫秒数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 date = (now-time)/(1000*60);//分钟数
            if(date>=(60*24*30*12)){
                console.log("8年前");
            }else if(date>=(60*24*30)){
                console.log("2个月前");
            }else if(date>=60*24){
                console.log("3天前");
            }else if(date>=60){
                console.log("8小时前");
            }else if(date>=1){
                console.log("3分钟前");
            }else if(date<1){
                console.log("刚刚");
            }
        }
        var str = friendlyDate( '1484286699422' );//2个月前  
        var str2 = friendlyDate('1583941245793');//刚刚
    
    

    相关文章

      网友评论

          本文标题:进阶任务-6

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