Math 和数组Date

Math任务

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

  function getRandom(min,max){
        return  Math.floor( min +  Math.random()*(max-min));
  } 
  console.log(getRandom(0.5,9.5));

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

   function getRandom(min,max){
      return  Math.floor( min +  Math.random()*(max-min+1));
   } 
    console.log(getRandom(1,10));

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

function getRandStr (num) {
  var arrstring='abcdefghiklmopqrstuvwxyzABCDEFGHIKLMNOPQRSTUVWXYZ0123456789';
  var arr = arrstring.split("");
  var arrreturn = [];
  for(var i=0;i

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

 function getRandIP(){
      var arr=[];
      for(var i =0;i<4;i++){
        arr[i]=getrandom(0,255)
      }
  return arr.join(".");
}
  function getrandom(min,max){
      return Math.floor(Math.random()*(max-min)) +min;
  }
var ip = getRandIP()
console.log(ip)

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

 function getRandColor(){
     var str="0123456789abcdef";
     var arr=[];
    for(var i=0;i<6;i++){
      arr.push(str[getrandom(0,str.length)])
    }
    arr.unshift("#");
    return arr.join("");
  }
  function getrandom(min,max){
     return Math.floor(Math.random()*(max-min)) +min;
  }
var color = getRandColor()
console.log(color)   // #3e2f1b

数组任务

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

栈方法:pop()、push();
  • push() 方法可向数组的末尾添加一个或多个元素,并返回新的长度。
    push() 方法可把它的参数顺序添加到 数组的尾部。它直接修改原数组,而不是创建一个新的数组。


    Math 和数组Date_第1张图片
    push.png
  • pop()方法用于删除并返回数组的最后一个元素。


    Math 和数组Date_第2张图片
    pop.png

push() 方法和 pop() 方法使用数组提供的先进后出栈的功能。

堆方法:shift()、unshift();
  • shift() 方法用于把数组的第一个元素从其中删除,并返回第一个元素的值。如果数组是空的,那么 shift() 方法将不进行任何操作,返回 undefined 值


    Math 和数组Date_第3张图片
    shift.png
  • unshift() 方法可向数组的开头添加一个或更多元素,并返回新的长度。


    Math 和数组Date_第4张图片
    unshift.png

*注释:以上方法均会改变数组的长度。

  • join() 方法用于把数组中的所有元素放入一个字符串。
    arrayObject.join(separator),separator为数组中个项的链接方式,不写默认为逗号。


    Math 和数组Date_第5张图片
    join.png
  • splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。
    arrayObject.splice(index,howmany,item1,.....,itemX)
    index: 必需。 整数,规定添加/删除项目的位置,使用负数可从数组结尾处规定位置。
    howmany: 必需。要删除的项目数量。如果设置为 0,则不会删除项目。
    item1, ..., itemX: 可选。向数组添加的新项目
    Math 和数组Date_第6张图片

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

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

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

function filterPositive(arr){
      var newarr=[];
      for(var i = 0;i0 && typeof arr[i] !="string" && typeof arr[i]!="boolean" ){
        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 任务

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

   function getChIntv (str) {
     var intervalMsec =Math.abs(new Date() - new Date(str));
    var intervaSec = parseInt(intervalMsec/1000);
    var seconds = intervaSec%60;
    var totalMinutes = parseInt(intervaSec/60);
    var minutes = totalMinutes%60;
    var totalhour = parseInt(totalMinutes/60);
    var hours = totalhour%24;
    var days = parseInt(totalhour/24);
    return "距离\"" +str +"\""+ days+"天" +Math.abs(hours-8)+"小时"+minutes+"分"+seconds+"秒";
}
var str = getChIntv("2017-7-20");
console.log(str);  

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

   function getChsDate (str) {
     var timearr=str.split("-");  
     var matcharr = ["零","一","二","三","四","五","六","七","八","九","十","十一","十二","十三","十四","十五","十六","十七","十八","十九","二十","二十一","二十二","二十三","二十四","二十五","二十六","二十七","二十八","二十九","三十","三十一"] ;
     var newarr=[];
    for(var i =0 ;i

3、写一个函数,参数为时间对象毫秒数的字符串格式,返回值为字符串。假设参数为时间对象毫秒数t,根据t的时间分别返回如下字符串:

function getChIntv (str) {
 var intervalMsec =Math.abs(Number(new Date())- Number(str));
 var intervaSec = parseInt(intervalMsec/1000);
 var seconds = intervaSec%60;
 var totalMinutes = parseInt(intervaSec/60);
 var minutes = totalMinutes%60;
 var totalhour = parseInt(totalMinutes/60);
 var hours = totalhour%24;
 var totaldays = parseInt(totalhour/24);
 var days = totaldays%30;
 var totalmouth = parseInt(totaldays/30);
 var mounthes = totalmouth%12;
 var years = parseInt(totalmouth/12);
   if(years>=1){
      return years+"年前"
   }else if(mounthes>=1&&mounthes<12){
      return mounthes+"月前"
   }else if(days>=3&&days<30){
      return days+"天前"
   }else if(hours>=8&&hours<24){
    return hours +"小时前"
   }else if(minutes>=3&&minutes<60){
    return minutes+"分钟前"
   }else if(minutes<1){
     return "刚刚"
    }
}
var str = getChIntv("1499914800000");
console.log(str);

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