Math,Array,Date
2017-08-02 本文已影响0人
南山码农
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<leng;i++){
var j = Math.floor(Math.random()*62);
newStr+=obj[i];
}
return newStr;
}
console.log(randomString(10)); //Z6GH5fiLcv
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<arr.length;i++){
arr[i] = arr[i]*arr[i];
}
}
var arr = [2, 4, 6]
squareArr(arr)
console.log(arr) // [4, 16, 36]
3、写一个函数,操作数组,返回一个新数组,新数组中只包含正数,原数组不变
function filterPositive(arr){
var newArr=[];
var j=0;
for(i=0;i<arr.length;i++){
if(typeof arr[i]==='number'&&arr[i]>0){
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<year.length;i++){
year[i]=dict[year[i]];
}
year=year.join('')
var month=dict[Math.abs(arr[1])];
var day=dict[Math.abs(arr[2])];
return year+'年'+month+'月'+day+'日'
}
console.log(getChsDate("2019-09-07"))
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个月前