标签:对象 时间 var 日期 数学 date 操作 Math
数学处理
Math常用API
- 圆周率
Math.PI// 3.1415926535
- 生成随机数
Math.random()
生成的是0~1之间的随机小数,通常在实际项目中需要获取到一个范围内的随机整数,利用这个随机小数封装一个获取范围内的随机整数的函数:
functiongetRandom(a,b){
varmax=a;
varmin=b;
if(a<b){
max=b;
min=a;
}
returnparseInt(Math.random() *(max-min)) +min
}
- ---向上取整
向上取整的含义是一个数字的小数部分不够1,将他处理成1。例如:10条数据每页展示3条,前3页都能放3条数据,但是第4页只能放1条数据,虽然占不满1页,但也要占1页
Math.ceil(3.3) // 4
- 向下取整
向下取整跟parseInt()是一个意思,只要整数部分,舍掉小数部分得到整数
Math.floor(3.9) // 3
- 四舍五入
Math.round(3.3) // 3
Math.round(3.9) // 4
- 求次方
Math.pow(2,3) // 2的3次方,参数1是底数,参数2是幂数
- 绝对值
Math.abs(-6) // 6
Math.abs(6) // 6
- 最大值
Math.max(9,5,1,3,4,8,2,6) // 9
- 最小值
Math.max(9,5,1,3,4,8,2,6) // 1
- 正弦
Math.sin(Math.PI*30/180) // 0.5
- 余弦
Math.cos(Math.PI*60/180) // 0.5
进制的转换
10进制转其他进制:10进制数字.toString(进制数)
var x=110;
x.toString(2) // 转为2进制
x.toString(8) // 转为8进制
x.toString(16) // 转为16进制
其他进制转10进制:parseInt(数据,进制数)
var x="110"// 这是一个二进制的字符串表示
parseInt(x, 2) // 把这个字符串当做二进制, 转为十进制
var x="70"// 这是一个八进制的字符串表示
parseInt(x, 8) // 把这个字符串当做八进制, 转为十进制
var x="ff"// 这是一个十六进制的字符串表示
parseInt(x, 16) // 把这个字符串当做十六进制, 转为十进制
时间日期处理
js提供了一个构造函数Date,用来创建时间日期对象。所以跟时间日期有关的操作都是通过时间日期来操作的。
时间日期对象创建
var date=newDate()
console.log(date) // Tue Jul 30 2019 21:26:56 GMT+0800 (中国标准时间)
创建好的是一个对象,但是当输出的时候被浏览器自动转为字符串输出了。获取到的是当前本地的时间日期对象。如果把本地的时间日期改掉,获取到的时间日期对象会随着本地时间变化。
获取具体的时间日期
通过时间日期对象可以获取到具体的年月日时分秒,甚至毫秒和时间戳。
date.getFullYear(); // 获取到完整的时间日期对象中的年份
date.getMonth(); // 获取到时间日期对象中的月份 - 这里的月份是通过0~11来描述1~12月的
date.getDate(); // 获取到时间日期对象中的日
date.getDay(); // 获取时间日期对象中的星期几
date.getHours(); // 获取到时间日期对象中的时
date.getMinutes(); // 获取到时间日期对象中分
date.getSeconds(); // 获取到时间日期对象中的秒
date.getMilliseconds(); // 获取到时间日期对象中的毫秒 - 1秒=1000毫秒
date.getTime(); // 获取到时间日期对象对应的时间戳
时间戳,指的是,格林尼治时间1970年1月1日0点0分0秒到现在走过的毫秒数。利用时间戳可以方便计算时间,例如:计算100天以前是几月几号。
将年月日时分秒放在页面中显示:
var date=newDate();
var year=date.getFullYear();
var month=date.getMonth()+1;
var d=date.getDate();
var day=date.getDay();
var hour=date.getHours();
var minute=date.getMinutes();
var second=date.getSeconds();
document.write("现在是北京时间:"+year+"年"+month+"月"+d+"日。星期"+day+"。"+hour+"时"+minute+"分"+second+"秒");
设置时间日期
通过时间日期对象,可以将其中的年月日时分秒进行设置,改变时间日期对象的时间。
date.setFullYear(年份); // 设置时间日期对象中的年份
date.setMonth(当前月份-1); // 设置时间日期对象中的月份 - 这里的月份是通过0~11来描述1~12月的
date.setDate(日); // 设置时间日期对象中的日
date.setHours(时); // 设置时间日期对象中的时
date.setMinutes(分); // 设置时间日期对象中分
date.setSeconds(秒); // 设置时间日期对象中的秒
date.setMilliseconds(毫秒); // 设置时间日期对象中的毫秒
date.setTime(时间戳); // 设置时间日期对象对应的时间戳 - 直接用时间戳就能将时间日期对象中的年月日时分秒全部改变
星期几是不能设置的,是根据年月日生成的。
创建指定的时间日期对象
我们可以在创建时间日期对象的时候就指定时间:
var date=new Date("年-月-日 时:分:秒") // 也可以是英文版的时间字符串 - Sun May 13,2016
var date=new Date(年,月-1,日,时,分,秒)
var date=new Date(时间戳)
日期格式化
date.toLocalString();//本地风格的日期格式
date.toLocaleDateString(); // 获取日期
date.toLocaleTimeString(); // 获取时间
时间戳的获取
格林威治时间/格林尼治时间
Date.parse("2015-08-24") // 获取1970年到设定时间的毫秒数
new Date().getTime()
+newDate();
案例:
两个指定的日期相差多少天
var date1=new Date(2010,10,3);
var date2=new Date(2017,9,24);
var day=(date2.getTime()-date1.getTime())/(1000*60*60*24);/*不用考虑闰年否*/
console.log("相差"+day+"天");
100天以后是哪年哪月哪日
var date=+newDate()
date+=100*24*3600*1000
var newDate=new Date(date)
var year=new Date.getFullYear()
var month=new Date.getMonth() +1;
var d=new Date.getDate()
console.log('100天以后是'+year+'年'+month+'月'+d+'日')
标签:对象,时间,var,日期,数学,date,操作,Math 来源: https://blog.csdn.net/m0_45229352/article/details/123617663
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。