美文网首页
Math数组Date

Math数组Date

作者: kumabearplus | 来源:发表于2017-05-09 12:27 被阅读7次

    Math任务

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

      function getRandomNumber(min,max) {
        var number;
        number = Math.floor(min+Math.random()*(max-min))
        return number
      }
      var a = getRandomNumber(2,5)
      console.log(a)
    

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

    function getRandomNumber(min,max) {
        var number;
        number = Math.floor(min+Math.random()*(max-min+1))
        return number
      }
      var a = getRandomNumber(2,5)
      console.log(a)
    

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

      function getRandStr(len){
        var str2 = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
        var arr2 = str2.split('')
        var arr3 =[]
        for (var i = 0; i < len; i++) {
          arr3[i] = arr2[Math.floor(Math.random()*62)]
        }
        return arr3.join('')
      }
      var str = getRandStr(10);
      console.log(str)
    

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

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

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

      function getRandColor(){
        var str = '0123456789abcdef'
        var arr = str.split('')
        var arr2 = ['#']
        for (var i = 1; i < 7; i++) {
            arr2[i] = arr[Math.floor(Math.random()*16)]
        }
        return arr2.join('')
      }
      var color = getRandColor()
      console.log(color)
    

    数组任务

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

    • push: 向数组的末尾添加一个或更多元素,并返回新的数组长度。
    • pop: 删除并返回数组的最后一个元素
    • shift: 删除并返回数组的第一个元素
    • unshift: 向数组的开头添加一个或更多元素,并返回新的长度。
    • join: 把数组的所有元素放入一个字符串,元素通过指定的分隔符进行分隔,不会修改原数组内容。
    • splice:用于一次性解决数组添加、删除(这两种方法一结合就可以达到替换效果),方法有三个参数
      1.开始索引
      2.删除元素的个数
      3.插入的新元素,当然也可以写多个
    // arr.push(item)
    arr.splice(arr.length,0,item)
    // arr.pop()
    arr.splice(arr.length-1,1)
    // arr.unshift(item)
    arr.splice(0,0,item)
    // arr.shift()
    arr.splice(0,1)
    

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

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

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

      function filterPositive(arr){
        var arr2 = []
        for (var i = 0; i < arr.length; i++) {
          if (typeof arr[i]=='number'&&arr[i]>0) {
            arr2.push(arr[i])
          }
        }
        return arr2
      }
      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(data){
        var timeStart = new Date(data).getTime()
        var timeEnd = new Date().getTime()
        var result = timeStart - timeEnd
        var days = 1000*60*60*24
        var hours = 1000*60*60
        var minutes = 1000*60
        var seconds = 1000
        var getDays = Math.floor(result/days)
        var getHours = Math.floor(result%days/hours)
        var getMinutes = Math.floor(result%days%hours/minutes)
        var getSeconds = Math.floor(result%days%hours%minutes/seconds)
        return '距离除夕还有 '+getDays+'天 '+getHours+'小时 '+getMinutes+'分钟 '+getSeconds+'秒'
      }
      var str = getChIntv('2018-2-15') // '2018-02-15' 是UTC时间
      console.log(str)
    

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

      function getChsDate(date){
        var str1 = '零,一,二,三,四,五,六,七,八,九,十,十一,十二,十三,十四,十五,十六,十七,十八,十九,二十,二十一,二十二,二十三,二十四,二十五,二十六,二十七,二十八,二十九,三十,三十一'
        var arr = str1.split(',')
        var arr2 = date.split('-')
        var year = arr2[0]
        var month = arr2[1]
        var day = arr2[2]
        var chYear = arr[parseInt(year[0])]+arr[parseInt(year[1])]+arr[parseInt(year[2])]+arr[parseInt(year[3])]
        var chMonth = arr[parseInt(month)]
        var chDay = arr[parseInt(day)]
        return chYear+'年'+chMonth+'月'+chDay+'日'
      }
      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 timeStart = new Date().getTime()
        var timeEnd = time
        var result = timeStart-timeEnd
        if (result<1000*60) {
          console.log('刚刚')
        }else if (result<1000*60*60) {
          console.log(Math.floor(result/1000/60)+'分钟前')
        }else if (result<1000*60*60*24) {
          console.log(Math.floor(result/1000/60/60)+'小时前')
        }else if (result<1000*60*60*24*30) {
          console.log(Math.floor(result/1000/60/60/24)+'天前')
        }else if (result<1000*60*60*24*30*12) {
          console.log(Math.floor(result/1000/60/60/24/30)+'个月前')
        }else if (result>1000*60*60*24*30*12) {
          console.log(Math.floor(result/1000/60/60/24/30/12)+'年前')
        }
      }
      var str = friendlyDate( '1484286699422' ) //  1分钟前
      var str2 = friendlyDate('1483941245793') //4天前
    

    相关文章

      网友评论

          本文标题:Math数组Date

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