您好,欢迎访问一九零五行业门户网

关于Math、数组、Date的相关例子

math,数组和date在学习中经常会遇到,本篇将会对其进行讲解。
写一个函数,返回从min到max之间的 随机整数,包括min不包括max
function getrandom (min,max) { return math.floor(math.random()*(max-min) + min) }//math.floor 返回小于参数值的最大整数//math.random 返回[0,1)之间的随机数
写一个函数,返回从min都max之间的 随机整数,包括min包括max
function getrandom (min,max) { return math.floor(math.random()*(max-min+1) + min) }
写一个函数,生成一个长度为 n 的随机字符串,字符串字符的取值范围包括0到9,a到 z,a到z
function getrandomstr (n) { var dict = '0123456789'+ 'abcdefghijklnmopqrstuvwxyz'+ 'abcdefghijklmnopqrstuvwxyz'; //一个字典; var string = ''; for (i=0; i<n; i++) { string += dict[math.floor(math.random()*62)] ; } return string ; }
写一个函数,生成一个随机 ip 地址,一个合法的 ip 地址为 0.0.0.0~255.255.255.255
function getrandip(){ var iparr = []; for (i=0; i<4; i++) { iparr.push(math.floor(math.random()*256)); //push()方法把元素从尾部放进数组; } return iparr.join('.'); }var ip = getrandip()console.log(ip)
写一个函数,生成一个随机颜色字符串,合法的颜色为#000000~ #ffffff
function getcolor () { var dict = '0123456789abcdef' var color = '#'; for (i=0; i<6; i++) { color += dict[math.floor(math.random()*16)]; } return color; } getcolor() ;
数组方法里push、pop、shift、unshift、join、splice分别是什么作用?用 splice函数分别实现push、pop、shift、unshift方法
push()方法可以把一个元素从尾部插入数组,改变原数组长度和索引;
var a =[] ;
a.push(4);
a ; // [4]
pop()方法可以删除并返回数组的最后一个元素,改变原数组长度和索引;
var a =[1,2] ;
a.pop(); // 2a ; // [1]
shift()方法可以把数组的第一个元素从其中删除,并返回第一个元素的值,改变原数组长度和索引;
var a=[1,2,3,4];
a.shift(); //1;a; //[2,3,4]
unshift()方法可向数组的开头添加一个或更多元素,并返回新的长度,改变原数组长度和索引;
var a=[1,2,3,4,5];
a.unshift(7,8); //7a; //[7,8,1,2,3,4,5]
splice()方法可以向/从数组中添加/删除项目,然后返回被删除的项目,没有删除则返回空数组,改变原数组长度和索引;
var a=[1,2,3];
a.splice(0,1); //[1]; //从第0位开始,删除1位;a; //[2,3]
var a=[1,2,3];
a.splice(0,0,7,8); //[];从第0位开始,删除0位,插入7,8(从前插入);a; //[7,8,1,2,3];
var a=[1,2,3,4];
a.splice(1,1,7,8); //[2];从第1位开始,删除1位([2]),并插入7,8;a; //[1,7,8,3,4];
用splice()可以实现push()、pop()、shift()、unshift()这些方法;
var a =[1,2,3,4,5,6];
a.splice(a.length,0,n) // 实现push(),n为想要传入的元素;a.splice(a.length-1,1)// 实现pop();a.splice(0,1) // 实现shift();a.splice(0,0,n) // 实现unshift(),n为想要传入的元素;
写一个函数,操作数组,数组中的每一项变为原来的平方,在原数组上操作
function squarearr(arr){ for (i=0; i<arr.length; i++) { arr[i] = arr[i]*arr[i]; } return arr; }var arr = [2, 4, 6] squarearr(arr)console.log(arr) // [4,16,36]
写一个函数,操作数组,返回一个新数组,新数组中只包含正数,原数组不变
function filterpositive(arr){ var newarr = []; var k = 0; for (i=0; i<arr.length; i++) { if (typeof arr[i] === 'number') { //验证是否为数字 if(arr[i]>0) { newarr[k] = arr[i]; k++; } } } return newarr; }var arr = [3, -1, 2, '饥人谷', true]var newarr = filterpositive(arr)console.log(newarr) //[3, 2]console.log(arr) //[3, -1, 2, '饥人谷', true]
写一个函数getchintv,获取从当前时间到指定日期的间隔时间
//示例var str = getchintv("2017-02-08");console.log(str); // 距除夕还有 20 天 15 小时 20 分 10 秒 function getchintv(date) { var time = math.abs(date.now()-date.parse(date)); var day = math.floor(time/86400000); var hour = math.floor(time%86400000/3600000); var min = math.floor(time%86400000%3600000/60000) var s = math.floor(time%86400000%3600000%60000/1000) var ms = (time%86400000%3600000%60000%1000); return '距离'+date+': '+day+' 天 '+hour+' 小时 '+min+' 分钟 '+s+' 秒 '+ms+' 毫秒 '} getchintv('2017-04-08') //距离2017-04-08: 55 天 4 小时 0 分钟 45 秒 774 毫秒;
把hh-mm-dd格式数字日期改成中文日期
//示例var str = getchsdate('2015-01-08');console.log(str); // 二零一五年一月八日 var dict ={0:'零',1:'一',2:'二',3:'三',4:'四',5:'五',6:'六',7:'七',8:'八',9:'九', 10:'十',11:'十一',12:'十二',13:'十三',14:'十四',15:'十五',16:'十六', 17:'十七',18:'十八',19:'十九',20:'二十',21:'二十一',22:'二十二',23:'二十三', 24:'二十四',25:'二十五',26:'二十六',27:'二十七',28:'二十八',29:'二十九',30:'三十',31:'三十一'} function getcht (date) { time = date.split('-'); year = time[0].split(''); for (i=0; i<year.length; i++) { year[i] = dict[year[i]]; } month = dict[parseint(time[1])]; day = dict[parseint(time[2])]; return year.join('')+' 年 '+month+' 月 '+day+' 日'} getcht('2017-06-01') // 二零一七年六月一日;
写一个函数,参数为时间对象毫秒数的字符串格式,返回值为字符串。假设参数为时间对象毫秒数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 str = friendlydate( '1484286699422' ) // 1分钟前var str2 = friendlydate('1483941245793') //4天前 function friendlydate(time){ var nowt = date.now(); //date.now()获取当前时间距离1970年1月1日00:00:00的毫秒数 pastt = nowt-time; if (pastt<=60*1000) { return '刚刚' }if (pastt>60000 && pastt<3600*1000) { return math.floor(pastt/60000)+'分钟前' }if (pastt>=3600*1000 && pastt<24*3600*1000) { return math.floor(pastt/(3600*1000))+'小时前' }if (pastt>=24*3600*1000 && pastt<30*24*3600*1000) { return math.floor(pastt/(24*3600*1000))+'天前' }if (pastt>=30*24*3600*1000 && pastt<12*30*24*3600*1000) { return math.floor(pastt/(30*24*3600*1000))+'月前' }else { return math.floor(pastt/(360*24*3600*1000))+'年前' } } friendlydate(1496246400000) //一天前;
本篇详解math、数组和date相关内容和例子,更多的相关内容请关注。
相关推荐:
html5/css3相关的知识讲解
javascript操作dom常用api总结
javascript全总结之定时器&dom的document
以上就是关于math、数组、date的相关例子的详细内容。
其它类似信息

推荐信息