Math数组Date

Math任务

写一个函数,返回从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 getRandStr(n){
  var str="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
  var randomStr = "";
  var arr = str.split('');
  for (var i = 0; i < n; i++) {
     var random = Math.floor(Math.random()*arr.length);
      randomStr += arr[random];
   }
   return randomStr;
}

var str = getRandStr(10); // 0a3iJiRZap

写一个函数,生成一个随机 IP 地址,一个合法的 IP 地址为 0.0.0.0~255.255.255.255
function getRandIP(){
  var LEN = 4;
  var arr = [];
  for (var i = 0; i
写一个函数,生成一个随机颜色字符串,合法的颜色为#000000~ #ffffff

function getRandColor(){
  var color = "0123456789abcdef";
  var randomColor = [];
  var LEN = 6;
  colorArr = color.split('');
  for (var i = 0; i < LEN; i++) {
    var random = Math.floor(Math.random()*colorArr.length);
    randomColor.push(colorArr[random]);
  }
  randomColor = "#" + randomColor.join('');
  return randomColor;
}
var color = getRandColor()
console.log(color)   // #3e2f

数组任务

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

**push: ** 栈方法,在数组的末尾添加一个或多个元素,该方法返回数组新的length。

var arr = [1,2,3,4]
arr.push(5)  //返回值是5 是新数组的length

pop: 栈方法,在数组的末尾添加一项,该方法返回删除的那一项的值

var arr = [1, 2, 3, 4, 5];
arr.pop();   //返回值是5,是数组的最后一项的值

**shift: **shift方法可以删除数组index最小的元素,并让后面元素index减一,length也减一,与之对应的是unshift方法,用于向数组头部添加一个元素, 返回值都是操作项的值

var arr = [1, 2, 3];
arr .unshift(4);  //数组最前面添加一项,值为4
console.log(arr );  //[4, 1, 2, 3]
console.log(arr .length);  //4
console.log(arr .shift());  //4
console.log(arr );  //[1, 2, 3]
console.log(arr .length);  //3
```
**join:** join方法的作用是把数组元素(对象调用其toString()方法)使用参数作为连接符连接成一字符串,不会修改原数组内容,如果不提供参数,默认用逗号分隔。
```
var arr = [1, 2, 3, 4, 5];
console.log(a.join(',')); //1,2,3,4,5
console.log(a.join(' ')); //1 2 3 4 5
console.log(a.join('- ')); //1-2-3-4-5
```

**splice:** splice方法是JS提供的一次性解决数组添加、删除(这两种方法一结合就可以达到替换效果)的方法,
```
arr.splice(index, offset, newitem1, newitem2, newitem3......)
//index是从数组的索引,定义splice执行的起点位置,offset是从index开始后面的第几位,newitem是插入的新元素,可以插入多个元素,splice方法的返回值是删除元素组成的新数组,没有删除则返回空数组。
```
** 用 splice函数分别实现push、pop、shift、unshift方法**
```
//用 splice函数分别实现push、pop、shift、unshift方法
var arr = [1,2,3,4,5,6];
arr.splice(arr.length, 0, “push”);  //push
arr.splice(arr.length - 1, 1)  //pop
arr.splice(0, 1, "")  //shift
arr.splice(0, 0 ,"unshift")  //unshift


```
##### 写一个函数,操作数组,数组中的每一项变为原来的平方,在原数组上操作
```
function squareArr(arr){
  for (var i = 0; i0) {
      newArr.push(arr[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 任务
##### 写一个函数getChIntv,获取从当前时间到指定日期的间隔时间
```
var str = getChIntv("2017-02-08");
function getChIntv(timeStr){
  var then = new Date(timeStr);
  var now = new Date();
  var timeDis = now - then;
  var totalSeconds = Math.floor(timeDis/1000);
  var seconds = totalSeconds%60;
  var totalMinutes = Math.floor(timeDis/1000/60);
  var minutes = totalMinutes%60;
  var totalHours = Math.floor(timeDis/1000/60/60);
  var hours = totalHours%24;
  var days = Math.floor(timeDis/1000/60/60/24);
  if (timeDis > 0) {
    return "距离" + timeStr + "已经过去:" + days + "天" + hours + "小时" + minutes   + "分钟" + seconds + "秒";
  }
  return "距离" + timeStr + "还有:" + days + "天" + hours + "小时" + minutes   + "分钟" + seconds + "秒";
}
console.log(str)
```
##### 把hh-mm-dd格式数字日期改成中文日期

```
var str = getChIntv("2017-11-18");
function getChIntv(timeStr){
  var dict=['零','一','二','三','四','五','六','七','八','九','十'];
  var units = ['年','月','日'];
  var date = '';
  var j = 0;
  for (var i = 0; i < timeStr.length; i++) {
    if (timeStr[i] === '-') {
      date += units[j++];  //j++是先取j的值,然后++;++j是先++,然后取j的值;
      i++;                 //遍历到'-'时i++ 执行到下一个if时 遍历的是'-'后面的一位
      if (timeStr[i] === '0') {
        i++;               //遍历到'0'时i++ 跳过
      } else if (timeStr[i] === '1') {          //'-'后面的一位是'1'时
        date += dict[10];
        i++;                                    //下一次的i就是1后面的那个数字
      } else if (timeStr[i] >= 2) {             //'-'后面的一位是'2'时
        date += (dict[timeStr[i]] + dict[10]);
        i++;                                    //下一次的i就是1后面的那个数字
      }
    }
    date += dict[timeStr[i]];
  }
  date += units[j];                             //拼接'日'
  return date;
}
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 timeDis = new Date().getTime() - time;
  var min=timeDis/(1000*60);
  var hour=timeDis/(1000*60*60);
  var day=timeDis/(1000*60*60*24);
  var month=timeDis/(1000*60*60*24*30);
  var year=timeDis/(1000*60*60*24*30*12);
  if(min>0&&min<1){
    return "刚刚";
  }else if(min>=1 && hour<1){
      return '三分钟前';
  }else if(hour>=1 && hour<24){
      return '8小时前';
  }else if(hour>=24 && day<30){
      return '三天前';
  }else if (day>=30 && month<12){
      return '2个月前';
  }else if (year>=1){
      return '8年前';
  }
}
var str = friendlyDate( '1484286699422' ) //  1分钟前
var str2 = friendlyDate('1483941245793') //4天前
```

你可能感兴趣的:(Math数组Date)