0

0

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

jacklove

jacklove

发布时间:2018-05-21 15:05:05

|

1818人浏览过

|

来源于php中文网

原创

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

写一个函数,生成一个随机 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为想要传入的元素;

仿优购鞋子商城整站 for ECSHOP
仿优购鞋子商城整站 for ECSHOP

ECSHOP仿优购鞋子商城整站源码,程序基于ECSHOP 2.7.3 UFT8版本制作,适合服装,鞋子,家居等商城使用。目前程序未添加广告位,请自行在网站后台进行添加。具体添加方法,请查看SHOPEX5站点的相关教程。 安装方法:1。访问 :域名/install2. 按照程序提示进行安装.3.安装完成后,登陆网站后台.选择数据库管理--数据库备份--数据库还原.,导入之前的数据库。4.后台-模板管

下载

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

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

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

function filterPositive(arr){    var newArr = [];    var k = 0;    for (i=0; i0) {
                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

写一个函数,参数为时间对象毫秒数的字符串格式,返回值为字符串。假设参数为时间对象毫秒数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('1483941241245793') //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相关内容和例子,更多的相关内容请关注php中文网。

相关推荐:

HTML5/CSS3相关的知识讲解

Javascript操作DOM常用API总结

JavaScript全总结之定时器&DOM的document

相关专题

更多
Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

28

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

379

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

115

2026.01.21

java版本选择建议
java版本选择建议

本专题整合了java版本相关合集,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

9

2026.01.21

无人机驾驶证报考 uom民用无人机综合管理平台官网
无人机驾驶证报考 uom民用无人机综合管理平台官网

无人机驾驶证(CAAC执照)报考需年满16周岁,初中以上学历,身体健康(矫正视力1.0以上,无严重疾病),且无犯罪记录。个人需通过民航局授权的训练机构报名,经理论(法规、原理)、模拟飞行、实操(GPS/姿态模式)及地面站训练后考试合格,通常15-25天拿证。

47

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 3.4万人学习

Excel 教程
Excel 教程

共162课时 | 12.9万人学习

MongoDB 教程
MongoDB 教程

共17课时 | 2.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号