直接使用了默认Date构造函数必威,Date对象对日期

不同Node版本导致的Date构造函数问题及解决方法

2018/07/06 · JavaScript · Date

原文出处: 康建云   

近期在封装时间选择组件的单元测试时,为了构造出Date对象,直接使用了默认Date构造函数。自己本地开发,测试均无问题,push远程后,某个小伙伴在本地跑测试用例时,却无法通过,具体报错如下:

必威 1

通过截图信息,可以初步判断由于Date构造函数返回了不同日期导致,抱着好奇的态度查阅个各种资料后,竟然发现一个小小的日期构造函数里面大有文章,平时自己写起来都是浅尝辄止,没有深入了解过。下面将详细介绍这个破案过程,以免各位看客后续重蹈覆辙。

创建 Date 对象的语法:

Date 日期和时间对象

JavaScript Date对象介绍

  1. 介绍

 

  Date对象,是操作日期和时间的对象。Date对象对日期和时间的操作只能通过方法。

 

  1. 构造函数

 

2.1 new Date() :返回当前的本地日期和时间

参数:无

 

返回值:

 

{Date} 返回一个表示本地日期和时间的Date对象。

 

示例:

 

 

var dt = new Date();

console.log(dt); // => 返回一个表示本地日期和时间的Date对象

 

 

2.2 new Date(milliseconds) :把毫秒数转换为Date对象

参数:

 

①milliseconds {int} :毫秒数;表示从'1970/01/01 00:00:00'为起点,开始叠加的毫秒数。

 

注意:起点的时分秒还要加上当前所在的时区,北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00'

 

返回值:

 

{Date} 返回一个叠加后的Date对象。

 

示例:

 

 

var dt = new Date(1000 * 60 * 1); // 前进1分钟的毫秒数

console.log(dt); // => {Date}:1970/01/01 08:01:00

dt = new Date(-1000 * 60 * 1); // 倒退1分钟的毫秒数

console.log(dt); // => {Date}:1970/01/01 07:59:00

 

 

2.3 new Date(dateStr) :把字符串转换为Date对象

参数:

 

①dateStr {string} :可转换为Date对象的字符串(可省略时间);字符串的格式主要有两种:

 

1) yyyy/MM/dd HH:mm:ss (推荐):若省略时间,返回的Date对象的时间为 00:00:00。

 

2) yyyy-MM-dd HH:mm:ss :若省略时间,返回的Date对象的时间为 08:00:00(加上本地时区)。若不省略时间,此字符串在IE中会转换失败!

 

返回值:

 

{Date} 返回一个转换后的Date对象。

 

示例:

 

 

var dt = new Date('2014/12/25'); // yyyy/MM/dd

console.log(dt); // => {Date}:2014/12/25 00:00:00

dt = new Date('2014/12/25 12:00:00'); // yyyy/MM/dd HH:mm:ss

console.log(dt); // => {Date}:2014/12/25 12:00:00

 

dt = new Date('2014-12-25'); // yyyy-MM-dd

console.log(dt); // => {Date}:2014-12-25 08:00:00 (加上了东8区的时区)

dt = new Date('2014-12-25 12:00:00'); // yyyy-MM-dd HH:mm:ss (注意:此转换方式在IE中会报错!)

console.log(dt); // => {Date}:2014-12-25 12:00:00

 

 

2.4 new Date(year, month, opt_day, opt_hours, opt_minutes, opt_seconds, opt_milliseconds) :把年月日、时分秒转换为Date对象

参数:

 

①year {int} :年份;4位数字。如:1999、2014

 

②month {int} :月份;2位数字。从0开始计算,0表示1月份、11表示12月份。

 

③opt_day {int} 可选:号; 2位数字;从1开始计算,1表示1号。

 

④opt_hours {int} 可选:时;2位数字;取值0~23。

 

⑤opt_minutes {int} 可选:分;2位数字;取值0~59。

 

⑥opt_seconds {int} 可选:秒;2未数字;取值0~59。

 

⑦opt_milliseconds {int} 可选:毫秒;取值0~999。

 

返回值:

 

{Date} 返回一个转换后的Date对象。

 

示例:

 

var dt = new Date(2014, 11); // 2014年12月(这里输入的月份数字为11)

console.log(dt); // => {Date}:2014/12/01 00:00:00

dt = new Date(2014, 11, 25); // 2014年12月25日

console.log(dt); // => {Date}:2014/12/25 00:00:00

dt = new Date(2014, 11, 25, 15, 30, 40); // 2014年12月25日 15点30分40秒

console.log(dt); // => {Date}:2014/12/25 15:30:40

dt = new Date(2014, 12, 25); // 2014年13月25日(这里输入的月份数字为12,表示第13个月,跳转到第二年的1月)

console.log(dt); // => {Date}:2015/01/25

 

 

  1. 属性

 

无;Date对象对日期和时间的操作只能通过方法。

 

 

 

  1. 实例方法

 

  Date对象的实例方法主要分为2种形式:本地时间和UTC时间。同一个方法,一般都会有此2种时间格式操作(方法名带UTC的,就是操作UTC时间),这里主要介绍对本地时间的操作。

 

 

 

4.1 get方法

4.1.1 getFullYear() :返回Date对象的年份值;4位年份。

 

4.1.2 getMonth() :返回Date对象的月份值。从0开始,所以真实月份=返回值+1 。

 

4.1.3 getDate() :返回Date对象的月份中的日期值;值的范围1~31 。

 

4.1.4 getHours() :返回Date对象的小时值。

 

4.1.5 getMinutes() :返回Date对象的分钟值。

 

4.1.6 getSeconds() :返回Date对象的秒数值。

 

4.1.7 getMilliseconds() :返回Date对象的毫秒值。

 

4.1.8 getDay() :返回Date对象的一周中的星期值;0为星期天,1为星期一、2为星期二,依此类推

 

4.1.9 getTime() :返回Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00') 。

 

示例:

 

dt.getFullYear(); // => 2014:年

dt.getMonth(); // => 11:月;实际为12月份(月份从0开始计算)

dt.getDate(); // => 25:日

dt.getHours(); // => 15:时

dt.getMinutes(); // => 30:分

dt.getSeconds(); // => 40:秒

dt.getMilliseconds(); // => 333:毫秒

dt.getDay(); // => 4:星期几的值

dt.getTime(); // => 1419492640333 :返回Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')

 

 

4.2 set方法

4.2.1 setFullYear(year, opt_month, opt_date) :设置Date对象的年份值;4位年份。

 

4.2.2 setMonth(month, opt_date) :设置Date对象的月份值。0表示1月,11表示12月。

 

4.2.3 setDate(date) :设置Date对象的月份中的日期值;值的范围1~31 。

 

4.2.4 setHours(hour, opt_min, opt_sec, opt_msec) :设置Date对象的小时值。

 

4.2.5 setMinutes(min, opt_sec, opt_msec) :设置Date对象的分钟值。

 

4.2.6 setSeconds(sec, opt_msec) :设置Date对象的秒数值。

 

4.2.7 setMilliseconds(msec) :设置Date对象的毫秒值。

 

示例:

 

var dt = new Date();

dt.setFullYear(2014); // => 2014:年

dt.setMonth(11); // => 11:月;实际为12月份(月份从0开始计算)

dt.setDate(25); // => 25:日

dt.setHours(15); // => 15:时

dt.setMinutes(30); // => 30:分

dt.setSeconds(40); // => 40:秒

dt.setMilliseconds(333); // => 333:毫秒

console.log(dt); // =>  2014年12月25日 15点30分40秒 333毫秒

 

 

4.3 其他方法

4.3.1 toString() :将Date转换为一个'年月日 时分秒'字符串

 

4.3.2 toLocaleString() :将Date转换为一个'年月日 时分秒'的本地格式字符串

 

4.3.3 toDateString() :将Date转换为一个'年月日'字符串

 

4.3.4 toLocaleDateString() :将Date转换为一个'年月日'的本地格式字符串

 

4.3.5 toTimeString() :将Date转换为一个'时分秒'字符串

 

4.3.6 toLocaleTimeString() :将Date转换为一个'时分秒'的本地格式字符串

 

4.3.7 valueOf() :与getTime()一样, 返回Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00') 

 

示例:

 

var dt = new Date();

console.log(dt.toString()); // => Tue Dec 23 2014 22:56:11 GMT+0800 (中国标准时间) :将Date转换为一个'年月日 时分秒'字符串

console.log(dt.toLocaleString()); // => 2014年12月23日 下午10:56:11  :将Date转换为一个'年月日 时分秒'的本地格式字符串

 

console.log(dt.toDateString()); // => Tue Dec 23 2014 :将Date转换为一个'年月日'字符串

console.log(dt.toLocaleDateString()); // => 2014年12月23日 :将Date转换为一个'年月日'的本地格式字符串

 

console.log(dt.toTimeString()); // => 22:56:11 GMT+0800 (中国标准时间) :将Date转换为一个'时分秒'字符串

console.log(dt.toLocaleTimeString()); // => 下午10:56:11 :将Date转换为一个'时分秒'的本地格式字符串

 

console.log(dt.valueOf()); // => 返回Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')

 

 

  1. 静态方法

 

5.1 Date.now()

说明:返回当前日期和时间的Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00') 

 

参数:无

 

返回值:

 

{int} :当前时间与起始时间之间的毫秒数。

 

示例:

 

 

console.log(Date.now()); // => 1419431519276

  

 

5.2 Date.parse(dateStr)

说明:把字符串转换为Date对象 ,然后返回此Date对象与'1970/01/01 00:00:00'之间的毫秒值(北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00')

 

参数:

 

①dateStr {string} :可转换为Date对象的字符串(可省略时间);字符串的格式主要有两种:

 

1) yyyy/MM/dd HH:mm:ss (推荐):若省略时间,返回的Date对象的时间为 00:00:00。

 

2) yyyy-MM-dd HH:mm:ss :若省略时间,返回的Date对象的时间为 08:00:00(加上本地时区)。若不省略时间,此字符串在IE中返回NaN(非数字)!

 

返回值:

 

{int} 返回转换后的Date对象与起始时间之间的毫秒数。

 

示例:

 

 

console.log(Date.parse('2014/12/25 12:00:00')); // => 1419480000000

console.log(Date.parse('2014-12-25 12:00:00')); // => 1419480000000  (注意:此转换方式在IE中返回NaN!)

 

 

  1. 实际操作

 

6.1 C#的DateTime类型转换为Js的Date对象

说明:C#的DateTime类型通过Json序列化返回给前台的格式为:"/Date(1419492640000)/" 。中间的数字,表示DateTime的值与起始时间之间的毫秒数。

 

示例:

 

后台代码:简单的ashx

 

 

public void ProcessRequest (HttpContext context) {

    System.Web.Script.Serialization.JavaScriptSerializer js = new System.Web.Script.Serialization.JavaScriptSerializer();

    DateTime dt = DateTime.Parse("2014-12-25 15:30:40");

    string rs = js.Serialize(dt); // 序列化成Json

    context.Response.ContentType = "text/plain";

    context.Response.Write(rs);

}

前台代码:

 

 

var dateTimeJsonStr = '/Date(1419492640000)/'; // C# DateTime类型转换的Json格式

var msecStr = dateTimeJsonStr.toString().replace(//Date(([-]?d+))//gi, "$1"); // => '1419492640000' :通过正则替换,获取毫秒字符串

var msesInt = Number.parseInt(msecStr); // 毫秒字符串转换成数值

var dt = new Date(msesInt); // 初始化Date对象

console.log(dt.toLocaleString()); // => 2014年12月25日 下午3:30:40

 

 

6.2  获取倒计时

说明:计算当前时间离目的时间相差多少天时分。

 

示例:

 

/**

* 返回倒计时

* @param dt {Date}:目的Date对象

* @return {Strin} :返回倒计时:X天X时X分

*/

function getDownTime(dt) {

    // 1.获取倒计时

    var intervalMsec = dt - Date.now(); // 目的时间减去现在的时间,获取两者相差的毫秒数

    var intervalSec = intervalMsec / 1000; // 转换成秒数

    var day = parseInt(intervalSec / 3600 / 24); // 天数

    var hour = parseInt((intervalSec - day * 24 * 3600) / 3600); // 小时

    var min = parseInt((intervalSec - day * 24 * 3600 - hour * 3600) / 60); // 分钟

 

    // 2.若相差的毫秒小于0 ,表示目的时间小于当前时间,这时的取的值都是负的:-X天-时-分,显示时,只显示天数前面为负的就行。

    if (intervalMsec < 0) {

        hour = 0 - hour;

        min = 0 - min;

    }

 

    // 3.拼接字符串并返回

    var rs = day + '天' + hour + '时' + min + '分';

    return rs;

}

 

// 当前时间:2014/12/28 13:26

console.log(getDownTime(new Date('2015/06/01'))); // => 154天10时33分

console.log(getDownTime(new Date('2014/01/01'))); // => -361天13时26分

 

 

6.3 比较2个Date对象的大小

说明:可以对比2者的与起始时间的毫秒数,来区分大小。

 

示例:

 

var dt1 = new Date('2015/12/01');

var dt2 = new Date('2015/12/25');

console.log(dt1 > dt2); // => false

 

Date对象介绍 1. 介绍 Date对象,是操作日期和时间的对象。Date对象对日期和时间的操作只能通过方法。

  1. 构造函数 2.1 new Date() :返...

很多时候,我们可以利用JavaScript中Date对象的内置方法来格式化,如:

问题排查

按照一贯做法,出问题后先自己本地跑了一次测试用例,没有任何问题,初步就可以定位是开发环境问题。于是乎就看了下小伙伴nodejs版本号,版本号为6.10.0,而自己本地node版本号为10.3.0,于是在不同nodejs命令行下直接执行如下测试用例。

JavaScript

const defaultDate = new Date('1995-12-17T03:24:00'); console.log(defaultDate.toString());

1
2
3
const defaultDate = new Date('1995-12-17T03:24:00');
 
console.log(defaultDate.toString());

执行结果,

Node 6.10.0:

JavaScript

> const defaultDate = new Date('1995-12-17T03:24:00') > console.log(defaultDate.toString()) Sun Dec 17 1995 11:24:00 GMT +0800(中国标准时间)

1
2
3
4
> const defaultDate = new Date('1995-12-17T03:24:00')
> console.log(defaultDate.toString())
 
Sun Dec 17 1995 11:24:00 GMT +0800(中国标准时间)

Node 10.3.0:

JavaScript

const defaultDate = new Date('1995-12-17T03:24:00') undefined console.log(defaultDatae.toString()) Sun Dec 17 1995 03:24:00 GMT+0800 (中国标准时间)

1
2
3
4
const defaultDate = new Date('1995-12-17T03:24:00')
undefined
console.log(defaultDatae.toString())
Sun Dec 17 1995 03:24:00 GMT+0800 (中国标准时间)

到此基本确认了该问题是由Nodejs环境导致的问题。但是为什么会有这样的问题呢,跟着我继续深入探秘下Date构造函数。

复制代码 代码如下:

1. 介绍

复制代码 代码如下:

深入分析

结合问题,提炼出以下小示例,以供深入分析Date构造函数:

JavaScript

var d1 = new Date("1995/12/17 00:00:00"); var d2 = new Date("1995-12-17T00:00:00"); var d3 = new Date("1995-12-17T00:00:00Z"); console.log(d1.toString()); console.log(d2.toString()); console.log(d3.toString());

1
2
3
4
5
6
var d1 = new Date("1995/12/17 00:00:00");  
var d2 = new Date("1995-12-17T00:00:00");
var d3 = new Date("1995-12-17T00:00:00Z");
console.log(d1.toString());
console.log(d2.toString());
console.log(d3.toString());

nodejs 10.3.0执行结果:

JavaScript

> console.log(d1.toString()); Sun Dec 17 1995 00:00:00 GMT+0800 (中国标准时间) > console.log(d2.toString()); Sun Dec 17 1995 00:00:00 GMT+0800 (中国标准时间) > console.log(d3.toString()); Sun Dec 17 1995 08:00:00 GMT+0800 (中国标准时间)

1
2
3
4
5
6
> console.log(d1.toString());
Sun Dec 17 1995 00:00:00 GMT+0800 (中国标准时间)
> console.log(d2.toString());
Sun Dec 17 1995 00:00:00 GMT+0800 (中国标准时间)
> console.log(d3.toString());
Sun Dec 17 1995 08:00:00 GMT+0800 (中国标准时间)

nodejs 6.10.0执行结果:

JavaScript

> console.log(d1.toString()); Sun Dec 17 1995 00:00:00 GMT+0800 (中国标准时间) > console.log(d2.toString()); Sun Dec 17 1995 08:00:00 GMT+0800 (中国标准时间) > console.log(d3.toString()); Sun Dec 17 1995 08:00:00 GMT+0800 (中国标准时间)

1
2
3
4
5
6
> console.log(d1.toString());
Sun Dec 17 1995 00:00:00 GMT+0800 (中国标准时间)
> console.log(d2.toString());
Sun Dec 17 1995 08:00:00 GMT+0800 (中国标准时间)
> console.log(d3.toString());
Sun Dec 17 1995 08:00:00 GMT+0800 (中国标准时间)

为什么在不同环境下Nodejs的解析行为不一样呢?这就要提下JS中涉及到时间的相关规范了。

//Date 对象会自动把当前日期和时间保存为其初始值。
new Date();

  Date对象,是操作日期和时间的对象。Date对象对日期和时间的操作只能通过方法。

var d = new Date();
console.log(d); // 输出:Mon Nov 04 2013 21:50:33 GMT+0800 (中国标准时间)
console.log(d.toDateString()); // 日期字符串,输出:Mon Nov 04 2013
console.log(d.toGMTString()); // 格林威治时间,输出:Mon, 04 Nov 2013 14:03:05 GMT
console.log(d.toISOString()); // 国际标准组织(ISO)格式,输出:2013-11-04T14:03:05.420Z
console.log(d.toJSON()); // 输出:2013-11-04T14:03:05.420Z
console.log(d.toLocaleDateString()); // 转换为本地日期格式,视环境而定,输出:2013年11月4日
console.log(d.toLocaleString()); // 转换为本地日期和时间格式,视环境而定,输出:2013年11月4日 下午10:03:05
console.log(d.toLocaleTimeString()); // 转换为本地时间格式,视环境而定,输出:下午10:03:05
console.log(d.toString()); // 转换为字符串,输出:Mon Nov 04 2013 22:03:05 GMT+0800 (中国标准时间)
console.log(d.toTimeString()); // 转换为时间字符串,输出:22:03:05 GMT+0800 (中国标准时间)
console.log(d.toUTCString()); // 转换为世界时间,输出:Mon, 04 Nov 2013 14:03:05 GMT

相关规范

ISO8601标准[参考5]

该标准指定了如果为指定偏移时间就默认为当前时间。

必威 2

[ES5 规范][参考6]

指出了如果没有指定偏移量,默认偏移量为Z。

必威 3

[ES6 规范][参考7]

为了和ISO8601标准一致,又对该规范做了更改,如果时区偏移量不存在,日期时间将被解释为本地时间。

必威 4

//value-毫秒:代表自世界协调时1970年1月1日00:00:00开始的数值。
new Date(value);

2. 构造函数

如果上面的方法不能满足我们的要求,也可以自定义函数来格式化时间,如:

源码分析

为了确认该问题是由于不同规范导致的,我们就需要看下V8源码里面的实现了。 获取不同node版本对应的v8版本号,如下图所示:

JavaScript

//node 10.3.0 > process.versions.v8 '6.6.346.32-node.9' //node 6.10.0 > process.versions.v8 '5.1.281.93'

1
2
3
4
5
6
7
//node 10.3.0
> process.versions.v8
'6.6.346.32-node.9'
 
//node 6.10.0
> process.versions.v8
'5.1.281.93'

查看 v8 的不同版本下git提交记录可看到在6.6版本上已经增加了对ES6规范的支持 ,实现了如果时区偏移量不存在,日期时间将被解释为本地时间的效果。

必威 5

//dateString-日期字符串:表示日期的字符串值。此字符串应该是在parse方法中识别的格式。
new Date(dateString);

2.1 new Date() :返回当前的本地日期和时间
参数:无

复制代码 代码如下:

问题总结

回头看文章开头的用的日期构造函数导致的bug,就可以解释”1995-12-17T00:00:00″ 在低版本下输出1995-12-17T08:00:00,而高版本下输出1995-12-17T00:00:00的问题了。

通过上述规范和源码,低版本由于会加默认偏移量Z,默认就解析成0时区的时间,而我们在东八区,所以最终我们本地的时间是1995-12-17T08:00:00,高版本下由于没有Z,默认会解析成本地时间,输出结果最终就是1995-12-17T00:00:00。

问题解决方案就是只需要加上时间偏移量即可,如下new Date(‘1995-12-17T03:24:00+08:00’)。

//year-年:代表年份的整数值。为了避免2000年问题最好指定4位数的年份; 使用1998, 而不要用98
//month-月:代表月份的整数值从0(1月)到11(12月)
//day-日:代表一个月中的第几天的整数值,从1开始
//hour-小时:代表一天中的小时数的整数值 (24小时制)
//minute-分钟
//second-秒
//millisecond-毫秒
new Date(year, month, day [, hour, minute, second, millisecond]);

返回值:

Date.prototype.format = function(format) {
       var date = {
              "M+": this.getMonth() + 1,
              "d+": this.getDate(),
              "h+": this.getHours(),
              "m+": this.getMinutes(),
              "s+": this.getSeconds(),
              "q+": Math.floor((this.getMonth() + 3) / 3),
              "S+": this.getMilliseconds()
       };
       if (/(y+)/i.test(format)) {
              format = format.replace(RegExp.$1, (this.getFullYear() + '').substr(4 - RegExp.$1.length));
       }
       for (var k in date) {
              if (new RegExp("(" + k + ")").test(format)) {
                     format = format.replace(RegExp.$1, RegExp.$1.length == 1
                            ? date[k] : ("00" + date[k]).substr((""

经验教训

由于浏览器的差异和不一致,强烈建议不要 使用Date构造函数解析日期字符串(并且Date.parse它们是等价的)。

尽可能使用“YYYY / MM / DD”作为日期字符串,或者使用年月时分秒的构造函数来构造Date对象,他们得到普遍地支持。有了这种格式,所有的时间都是本地的。

除非您知道自己在做什么,否则请避免使用带有连字符号的日期(”YYYY-MM-DD”),只有较新的浏览器支持它们。

Date()

{Date} 返回一个表示本地日期和时间的Date对象。

  • date[k]).length));
                  }
           }
           return format;
    }
    var d = new Date().format('yyyy-MM-dd');
    console.log(d); // 2013-11-04

参考

[1]

[2]

[3]

[4]

[5]

[6]

[7]

1 赞 1 收藏 评论

必威 6

Date() 方法可返回当天的日期和时间。

示例:

 

复制代码 代码如下:

复制代码 代码如下:

复制代码 代码如下: var d = new Date(); console.log(d); // 输出:Mon Nov 04 2...

console.log(Date());  //"Tue Sep 17 2013 12:22:55 GMT+0800 (中国标准时间)"

var dt = new Date();
console.log(dt); // => 返回一个表示本地日期和时间的Date对象

parse()

2.2 new Date(milliseconds) :把毫秒数转换为Date对象
参数:

parse() 方法可解析一个日期时间字符串,并返回 1970/1/1 午夜距离该日期时间的毫秒数。

①milliseconds {int} :毫秒数;表示从'1970/01/01 00:00:00'为起点,开始叠加的毫秒数。

Date.parse(datestring)

注意:起点的时分秒还要加上当前所在的时区,北京时间的时区为东8区,起点时间实际为:'1970/01/01 08:00:00'

参数datestring是必需的,表示日期和时间的字符串。

返回值:

注意,该方法是 Date 对象的静态方法。一般采用 Date.parse() 的形式来调用,而不是通过 dateobject.parse() 调用该方法。

{Date} 返回一个叠加后的Date对象。

复制代码 代码如下:

示例:

console.log(Date.parse(Date()));        //1379392301000
console.log(Date.parse("Aug 9, 1995")); //807897600000

复制代码 代码如下:

UTC()

var dt = new Date(1000 * 60 * 1); // 前进1分钟的毫秒数
console.log(dt); // => {Date}:1970/01/01 08:01:00
dt = new Date(-1000 * 60 * 1); // 倒退1分钟的毫秒数
console.log(dt); // => {Date}:1970/01/01 07:59:00

UTC() 方法可根据世界时返回 1970 年 1 月 1 日 到指定日期的毫秒数。

2.3 new Date(dateStr) :把字符串转换为Date对象
参数:

Date.UTC(year, month, day, hours, minutes, seconds, ms)

①dateStr {string} :可转换为Date对象的字符串(可省略时间);字符串的格式主要有两种:

参数year是必需的,表示年份的四位数字;month是必需的,表示月份的整数,介于 0 ~ 11;day是可选的,表示日期的整数,介于 1 ~ 31;hours是可选的,表示小时的整数,介于 0 ~ 23;minutes是可选的,表示分钟的整数,介于 0 ~ 59;seconds是可选的,表示秒的整数,介于 0 ~ 59;ms是可选的,表示毫秒的整数,介于 0 ~ 999。

1) yyyy/MM/dd HH:mm:ss (推荐):若省略时间,返回的Date对象的时间为 00:00:00。

Date.UTC() 是一种静态方法。Date.UTC() 方法的参数指定日期和时间,它们都是 UTC 时间,处于 GMT 时区。指定的 UTC 时间将转换成毫秒的形式,这样构造函数 Date() 和方法 Date.setTime() 就可以使用它了。

2) yyyy-MM-dd HH:mm:ss :若省略时间,返回的Date对象的时间为 08:00:00(加上本地时区)。若不省略时间,此字符串在IE中会转换失败!

ECMAScript中的Date类型是早期Java中的Java.util.Date类基础上构建的。为此,Date类型使用来自UTC(Coordinated Universal Time,国际协调时间)1970年1月1日午夜(零时)开始经过的毫秒数来保存日期。在使用这种数据存储格式的条件下,Date类型保存的日期能够精确到1970年1月1日之前或之后的285616年。

返回值:

本文由必威发布于必威-前端,转载请注明出处:直接使用了默认Date构造函数必威,Date对象对日期

相关阅读