进阶任务6:Math数组Date

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

function random(min, max) {
         return min + Math.floor(Math.random()*(max-min))
     }
     var arr = [];
     for(var i=0; i<10; i++){
         arr.push(random(min,max))
     }
     console.log(arr)

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

function random(min, max) {
         return min + Math.floor(Math.random()*(max-min))
     }
     var arr = [];
     for(var i=0; i<10; i++){
         arr.push(random(min,max+1))
     }
     console.log(arr)

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

function  getRanStr(len) {
    var dict = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHEIJKLMNOQPRSTUVWXYZ"
    var str = ""
    for(var i = 0; i < len; i++){
        str += dict[Math.floor(Math.random()*62)]
    }
    return str
}
console.log(getRanStr(10))

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) 
        var ip = arr.join('.')
    }
return ip
}
console.log(getRandIP())

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

  function getRandColor() {
        var dict = '0123456789abcdef'
        var str = ''
        for(var i = 0; i < 6; i++){
            str += dict[random(0,16)]
        }
        str = '#'+str
        return str
    }
    console.log(getRandColor())

数组任务

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

  • push: 栈方法,在数组最后添加值,返回数组长度;
  • pop: 栈方法,取出数组最后一个值,返回被删除的元素;
  • shit: 队列方法,删除数组最前面的值,返回被删除的元素;
  • unshift: 队列方法,在数组最前面添加一个或多个值,返回数组长度;
  • join:以指定分隔符将数组的值链接成字符串,返回生成的新字符串,()内接受指定分隔符参数,若为空字符,则元素直接联结成字符串;
  • JavaScript提供了一个splice方法用于一次性解决数组添加、删除(这两种方法一结合就可以达到替换效果),方法有三个参数:1.开始索引;2.删除元素的位移;3.插入的新元素,当然也可以写多个。splice方法返回一个由删除元素组成的新数组,没有删除则返回空数组。
  • 用 splice函数分别实现push、pop、shift、unshift方法:
1.push:

   var arr = [1,2,3,6,7,9]
  function spliceToPush(arr, elements) {
      arr.splice(arr.length, 0, elements)
      return arr
  }
    console.log(spliceToPush(arr, 'asd')) // [1, 2, 3, 6, 7, 9, "asd"]


2.pop:

 var arr = [1, 2, 3]
function spliceToPop(arr) {
 arr.splice(arr.length - 1,1)
    return arr
}
console.log(spliceToPop(arr)) // [1, 2]

3.shit:

var arr = [1,2,3,4,5,6,7]
    function spliceToShift(arr) {
        arr.splice(0,1)
        return arr
    }
    console.log(spliceToShift(arr)) // [2, 3, 4, 5, 6, 7]

4.unshit:

var arr = [1,2,3,4,5,6,7]
    function spliceToUnshift(arr, elements) {
        arr.splice(0, 0, elements)
        return arr
    }
    console.log(spliceToUnshift(arr, 'asddsa')) // ["asddsa", 1, 2, 3, 4, 5, 6, 7]

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

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

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

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

    }
    return newArr
}
var newArr = filterPositive(arr)
console.log(newArr)//[3,2]
console.log(arr)//[3, -1,  2,  '饥人谷', true]

Date 任务

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

function getChIntv(str){
  var timeEnd = Date.parse(str);
  var timeStart = new Date().getTime();
  var offset = timeEnd - timeStart;
  var days = parseInt(offset/(24*60*60*1000));
  var hours = parseInt(offset%(24*60*60*1000)/(60*60*1000));
  var minutes  = parseInt(offset%(24*60*60*1000)%(60*60*1000)/(60*1000))
  var seconds =  parseInt(offset%(24*60*60*1000)%(60*60*1000)%(60*1000)/1000)
  console.log(seconds);
  var str ='距离'+str+'还有'+days+'天'+
            hours +'小时' + minutes +'分'+ seconds +'秒';
  return str;
}

var str = getChIntv("2017-02-08");
console.log(str);

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

function getChsDate(date1){
            var chs ={"0":"零","1":"一","2":"二","3":"三","4":"四","5":"五","6":"六","7":"七","8":"八","9":"九","10":"十","11":"十一","12":"十二","13":"十三","14":"十四","15":"十五","16":"十六","17":"十七","18":"十八","19":"十九","20":"二十","21":"二十一","22":"二十二","23":"二十三","24":"二十四","25":"二十五","26":"二十一六","27":"二十七","28":"二十八","29":"二十九","30":"三十","31":"三十一"};
            var str="";
            var date2 =new Date(date1);
            var year= date2.getFullYear().toString();
            str+=chs[year[0]];
            str+=chs[year[1]];
            str+=chs[year[2]];
            str+=chs[year[3]];
            str +="年";
            str +=chs[date2.getMonth()+1];
            str +="月";
            str +=chs[date2.getDate()];
            str +="日";
            return str;
        }


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 date=Date.now()-new Date(parseInt(time));
            var str;
            if(date<0){
                str = "那是未来";
            }else if(date<60*1000){
                 str = "刚刚";
            }else if(date<(3600*1000)){
                str =Math.floor(date/60/1000)+"分钟前";
            }else if(date<(24*3600*1000)){
                str =Math.floor(date/3600/1000)+"小时前";
            }else if(date<(30.41*24*3600*1000)){
                str =Math.floor(date/24/3600/1000) + "天前";
            }else if(date<(365.24*24*3600*1000)){
                str =Math.floor(date/30.41/24/3600/1000) + "月前";
            }else if(date<(10000*365.24*24*3600*1000)){
                str =Math.floor(date/365.24/24/3600/1000) + "年前";
            }
            return str;
        }
var str = friendlyDate( '1484286699422' ) //1分钟前
console.log(str);
var str2 = friendlyDate('1483941245793') //4天前
console.log(str2);

你可能感兴趣的:(进阶任务6:Math数组Date)