Math,Array,Date

Math

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

function getrRndomnumber(min,max){
    return Math.random()*(max-min)+min;
}
console.log(getrRndomnumber()3,9);   //7.131521726958454

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

function getrRndomint(min,max){
    return Math.floor(Math.random()*(max-min+1)+min)
}
console.log(getrRndomint(3,9));     //5

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

function getRandomstring(leng){
    var  dict='0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ';
    var obj=dict.split('');
    var newStr=''        
    for(i=0;i

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

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

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

function getRandColor(){
    var  dict='0123456789abcdef';
    var obj=dict.split('');
    var str='#';
    for(i=0;i<6;i++){
          var j = Math.floor(Math.random()*16);
          str+=obj[j];
    }
  return str;
}
var color = getRandColor()
console.log(color)   // #3e2f1b

数组任务

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

  • 栈方法(先入后出)
    pop和push能够让我们使用堆栈那样先入后出使用数组
    arr.pop() //删除数组最后一个数,并且数组长度减一;
    arr.push(number) //数组最后添加一位数,并且数组长度加一;
  • 队列方法(先入先出)
    arr.shift() //删除数组下标最小的数,同时,后面元素index都减一,length也减一;
    arr.unshift(number) //向数组头部添加一个元素,后面元素index都加一,length也加一;
  • 终极大招
    splice方法用于一次性解决数组添加、删除(这两种方法一结合就可以达到替换效果),方法有三个参数
    1.开始索引(元素下标)
    2.删除元素的位移()长度
    3.插入的新元素,当然也可以写多个(插入数)
    arr.splice(number,number,number,number)
  • 用splice实现push、pop、shift、unshift
    arr.push(number) arr.splice(arr.length,0,number)
    arr.pop() arr.splice(arr.length-1,1)
    arr.shift() arr.splice(0,1)
    arr.unshift(number) arr.splice(0,0,number)

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

function squareArr(arr){
  for(i=0;i

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

function filterPositive(arr){
  var newArr=[];
  var j=0;
  for(i=0;i0){
        newArr[j]=arr[i];
        j++;
    }
  }
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 getChlntv(time){
    var now=Date.now();
    var then=new Date(time);
    var str='还有';
    if ((then-now)<0) {
        var str='已经过去';
    }
    var intv=Math.abs(then-now);
    var ms=intv%1000;
    var intv_second=(intv-ms)/1000;
    var second=intv_second%60;
    var intv_minutes=(intv_second-second)/60;
    var minutes=intv_minutes%60;
    var intv_hour=(intv_minutes-minutes)/60;
    var hour=intv_hour%24;
    var intv_day=(intv_hour-hour)/24;
    var day=intv_day%30;
    var intv_month=(intv_day-day)/30;
    var month=intv_month%12
    var year=(intv_month-month)/12;
    return '距离'+time+str+year+'年'+month+'月'+day+'日'+hour+'时'+minutes+'分'+second+'秒'+ms+'毫秒';
}
var str = getChIntv("2017-02-08");
console.log(str);  // 距离2017-02-08已经过去0年5月25日4时48分42秒689毫秒

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

function getChsDate(time){
    var dict=["零","一","二","三","四","五","六","七","八","九","十","十一","十二","十三","十四","十五","十六","十七","十八","十九","二十","二十一","二十二","二十三","二十四","二十五","二十六","二十七","二十八","二十九","三十","三十一"]
    var arr=time.split('-');
    var year=arr[0].split('');
    for(i=0;i

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=new Date()
    t=now-time
    if(t<60*1000){
        return '刚刚';
    }else if(t<60*60*1000) {
        return '3分钟前'
    }else if(t<24*60*60*1000) {
        return '8小时前'
    }else if(t<30*24*60*60*1000) {
        return '3天前'
    }else if(t<12*30*24*60*60*1000) {
        return '2个月前'
    }else  {
        return '8年前'
    }
}
console.log(friendlyDate('1484286699422'))  //2个月前

你可能感兴趣的:(Math,Array,Date)