Math、数组、Date

Math任务

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

function rand(min,max){ return parseInt(Math.random()*(max-min)); } console.log(rand(3,8));

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

function rand(min,max){ return parseInt(Math.random()*(max+1-min))+min; } console.log(rand(3,8));

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

function getRandStr(len){ var res=""; var idex; var str="0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"; 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.push(parseInt(Math.random()*256)); } return arr.join("."); } var ip = getRandIP() console.log(ip); //7.142.158.75

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

function getRandColor(){ var arr=["#"]; var num; var str="0123456789abcdef"; for(var i=0;i<6;i++){ num=parseInt(Math.random()*str.length); arr.push(str[num]); } return arr.join(""); } var color = getRandColor(); console.log(color) ; //#47489b

数组任务

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

作用:

  • push:末位加上一个或多个元素,数组长度+1或+n;
  • pop:取出末位的一个元素,数组长度-1;
  • shift:取出首位的一个元素,数组长度-1;
  • unshift:首位加上一个或多个元素,数组长度+1或+n;
  • join:传入一个参数(缺省值为','),将按照该参数将数组连接成字符串;
  • split():方法将一个String对象分割成字符串数组,通过
    将字符串分成子串。

`var arr = [1,2,3];
//push方法的实现
function fPush(arr,element){
arr.splice(arr.length,0,element);

return arr;
}
console.log(fPush(arr,5));
//pop方法的实现
function fPop(arr){
arr.splice(arr.length-1,1);
return arr;
}
console.log(fPop(arr));
//shift方法的实现
function fUnshift(arr){
arr.splice(0,1);
return arr;
}
console.log(fUnshift(arr));
//unshift的实现方法
function fUnshift(arr,element){
arr.splice(0,0,element);
return arr;
}
console.log(fUnshift(arr,5));`

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

function squareArr(arr){ arr.forEach(function(e,i){ arr[i]=e*e; }); }; var arr = [2, 4, 6]; squareArr(arr); console.log(arr) ;// [4, 16, 36]

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

function filterPositive(arr) { return arr.filter(function(e){ return typeof e === 'number' && e > 0; }); }; var arr = [3, -1, 2, '饥人谷', true]; var newArr = filterPositive(arr); console.log(newArr); //[3,2]

Date 任务

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

function getChIntv(timestr){ var time = new Date( timestr ).getTime()-8*60*60*1000; var now = Date.now(); var diff = time - now; var day = parseInt(diff/( 1000*60*60*24 )); var hour = parseInt(( diff%( 1000*60*60*24 ) )/( 60*60*1000 )); var minute = parseInt(( diff%( 1000*60*60 ) )/( 60*1000 )); var second = parseInt(( diff%( 1000*60 ) )/( 1000 )); return "距明天还有" + day +"天" + hour +"小时" + minute + "分" + second + "秒"; } console.log( getChIntv("2017-03-24") );

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

`function getChsDate(timeStr){
var res = [];
var dic = ['零','一','二','三','四','五','六','七','八','九','十','十一','十二','十三','十四','十五','十六','十七','十八','十九', '二十','二十一','二十二','二十三','二十四','二十五','二十六','二十七','二十八','二十九', '三十','三十一'];
var arr = timeStr.split('-'),
year = arr[0],
month = arr[1],
day=arr[2];
for(var i in year){
res.push(dic[year[i]]);
}
res.push('年');
res.push(dic[parseInt(month)]);
res.push('月');
res.push(dic[parseInt(day)]);

res.push('日');
return res.join('');

}
var str = getChsDate('2017-03-23');
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 now = Date.now(), diffTime = now - time; var SECOND = 1000, MINUTE = SECOND * 60, HOUR = MINUTE * 60, DAY = HOUR * 24, MONTH = DAY * 30, YEAR = MONTH * 12; var num; if (diffTime >= YEAR) { num = parseInt(diffTime / YEAR); return num + "年前"; } else if (diffTime >= MONTH) { num = parseInt(diffTime / MONTH); return num + "个月前"; } else if (diffTime >= DAY) { num = parseInt(diffTime / DAY); return num + "天前"; } else if (diffTime >= HOUR) { num = parseInt(diffTime / HOUR); return num + "小时前"; } else if (diffTime >= MINUTE) { num = parseInt(diffTime / MINUTE); return num + "分钟前"; } else if (diffTime >= 0) { return "刚刚"; } } var str = friendlyDate(Date.now()-1000*60); var str2 = friendlyDate(Date.now()-1000*60*60*24*4); console.log(str); //1分钟前 console.log(str2) //4天前;

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