日月如梭,玩转JavaScript日期

简介: Date对象

一、Date对象

下面出现的源码都可以codepen在线查看

1)时间戳毫秒计算

Date对象是基于“1970-01-01 08:00:00”到指定日期的毫秒数,不是“00:00:00”。

一天由86,400,000毫秒组成。

var begin = new Date(1970,0,1,0,0,0);//-28800000
begin = new Date(1970,0,1,8,0,0);//0

1.png

通过上面的代码打印结果,可以看到是相对于8点的毫秒数。

PHP中的时间戳是秒,所以在和PHP互动的时候,要除以1000换算成秒。

2)构造函数

Date的构造函数可以传多种组合的参数:

1112.png

var date1 = new Date("January 20,2017 11:11:05");
var date2 = new Date("January 20,2017");
var date3 = new Date("2017/01/20 11:11:05");
var date4 = new Date("2017/01/20");
var date5 = new Date(2017,0,20,11,11,5); //月份从0~11
var date6 = new Date(2017,0,20);
var date7 = new Date(1484881865000);

var date1 = new Date("January 20,2017 11:11:05");

var date2 = new Date("January 20,2017");

var date3 = new Date("2017/01/20 11:11:05");

var date4 = new Date("2017/01/20");

var date5 = new Date(2017,0,20,11,11,5); //月份从0~11

var date6 = new Date(2017,0,20);

var date7 = new Date(1484881865000);

 A2.png

二、Date对象方法

这里只列出部分,更多方法可以参考《JavaScript Date 对象

下面是图片,不用选中复制了,想复制就点击上面的地址!

Q.png

月份的范围是“0-11”,而不是“1-12”。

var date = new Date(); //获取一个时间对象
var year = date.getFullYear();  // 获取完整的年份(4位,1970)
var month = date.getMonth();  // 获取月份(0-11,0代表1月,用的时候记得加上1)
var day = date.getDate();  // 获取日(1-31)
var hour = date.getHours();  // 获取小时数(0-23)
var minute = date.getMinutes();  // 获取分钟数(0-59)
var second = date.getSeconds();  // 获取秒数(0-59)
var week = date.getDay();  // 获取一周中的某一天(0-6) 其中周日是0周六是6

 W.png

三、日期转换时间戳

1. 人类比较喜欢的格式是“2017-01-20 11:11:05:123”;

2. 浏览器更喜欢的格式是“2017/01/20 11:11:05:123

第一种格式在转换为时间戳的时候,会有兼容问题,下图所示,更多兼容问题可以参考《JavaScript Date parsing behavior

E.png

可以分两步走,第一步是将格式替换为浏览器喜欢的,第二步是使用方法获取。

1)格式替换

下面的替换用到了简单的正则,更多正则替换可以参考《飞起来的正则表达式》

var dateStr = '2017-01-20 11:11:05:123';
date = new Date(dateStr); //传入一个时间格式,如果不传入就是获取现在的时间了,这样做IOS做Date.parse会返回null
//另外一种方式
date = new Date(dateStr.replace(/-/g, '/'));


2)获取时间戳

用到了4种获取方式,隐式类型转换、getTimevalueOfDate.parse

前面3种精确到毫秒,而第4种只能精确到

time1 = +date;//隐式类型转换
time2 = date.getTime();
time3 = date.valueOf();//与getTime功能一样,该方法通常在 JavaScript 内部被调用,而不是在代码中显式调用。
time4 = Date.parse(date);//只能精确到秒

Z.png


其中隐式转换相当于下面的代码:

function(){ 
    return Number(new Date); 
}

}

上面的代码用到Number对象做转换。

还有更多的方法或对象,例如Boolean、String、Number、parseFloat、parseInt、ToInt32等,可以参考《Javascript Type-Conversion

“+”加号这个符号,可以将不同数据类型转成不同的值,具体行为可以参考《The unary + operator

21.png


 

四、常用扩展

1)计算相隔天数

两个日期相减,再除以各种时间单位的换算。

Math.abs(start - end) / 60 / 60 / 1000 / 24;

2)某个月的第一天

设置年月日,天设置为1,最终生成一个日期对象。

new Date(date.getFullYear(), date.getMonth(), 1);

3)某个月的最后一天

同样是三个参数,但最后一个天设置为0,月份设置为下一个月。

new Date(date.getFullYear(), date.getMonth()+1, 0)

4)某个月所在季度的第一天

日期的月份先除以3,再通过符号“~~”获取到整数部分(0、1、2或3),再乘以3获取到季度的第一个月。

//~~作用是将数字转化为32位有符号整数 舍去小数不做四舍五入
new Date(date.getFullYear(), ~~(date.getMonth()/3)*3, 1);

5)某个月所在季度的最后一天

计算方式与上面相同,不同的月份是再加“3”。

new Date(date.getFullYear(), ~~(date.getMonth()/3)*3 + 3, 0)

6)判断是否是闰年

月份设置3月,天设置0,就能获取到2月份的最后一天。

new Date(date.getFullYear(), 2, 0).getDate() == 29

7)某个月份的天数

设置这个日期的下一个月,天数为0。

new Date(date.getFullYear(), date.getMonth()+1, 0).getDate()

还有大家经常会用到的格式化,例如date.format('YYYY年MM月DD日'),返回“2017年01月20日”。

网上有很多代码实现方式,这里就不介绍了。

 

相关文章
|
22天前
|
JavaScript
JS设置日期为0时0分0秒
项目中经常要给设置默认值,搜索从哪天开始,这时候,如果直接通过new Date()来获取时间,会有时分秒,如果快速设置为0时0分0秒?
51 0
|
22天前
|
移动开发 JavaScript 前端开发
分享76个时间日期JS特效,总有一款适合您
分享76个时间日期JS特效,总有一款适合您
40 0
|
22天前
|
JavaScript 前端开发
javascript 如何判断字符串日期是否相差七天
在JavaScript中,你可以使用`Date`对象来比较两个日期之间的差异。下面是一个简单的示例,演示如何判断两个字符串日期是否相差七天: ```javascript function isSevenDaysDifference(date1, date2) { // 确保输入是字符串 if (typeof date1 !== 'string' || typeof date2 !== 'string') { return false; } // 将字符串转换为Date对象 var d1 = new Date(date1);
|
22天前
|
JavaScript 前端开发 UED
分享89个时间日期JS特效,总有一款适合您
分享89个时间日期JS特效,总有一款适合您
37 3
|
22天前
|
JavaScript 前端开发 Shell
JS获取当前时间、及一周之前、一个月之前日期
这段代码展示了JavaScript中获取当前时间以及过去特定日期的方法。包括获取时间戳和格式化日期的函数,例如获取一周、一个月前的日期。另外,还包含了添加随机数的日期时间戳生成和计算两个日期之间差值的示例。
|
22天前
|
JavaScript 前端开发
js对比日期大小
js对比日期大小
16 1
|
22天前
|
JavaScript 前端开发
实现一个JavaScript动态日期功能
实现一个JavaScript动态日期功能
|
22天前
|
JavaScript 前端开发
JavaScript 日期对象
JavaScript 日期对象
|
22天前
|
JavaScript 前端开发
使用JavaScript实现一个复杂功能:日期范围选择器
使用JavaScript实现一个复杂功能:日期范围选择器
|
22天前
|
资源调度 JavaScript 前端开发
jc-datetime :JavaScript 日期时间实用编程
jc-datetime :JavaScript 日期时间实用编程
162 1