Date日期和岁月对象,JavaScript原生对象之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对象的年BlackBerry08: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意味十一月份、11意味1十二月份。

 

③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); // 二零一四年15月(那里输入的月度数字为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); //
二零一四年11十二月25日(那里输入的月度数字为12,表示第1三个月,跳转到第二年的6月)

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 get米尔(Mill)iseconds() :重返Date对象的飞秒值。

 

4.1.8 getDay()
:再次回到Date对象的七天中的星期值;0为周六,1为周三、2为周日,依此类推

 

4.1.9 get提姆e() :再次回到Date对象与’1970/01/01
00:00:00’之间的飞秒值(新加坡时间的时区为东8区,起源时间莫过于为:’1970/01/01
08:00:00′) 。

 

示例:

 

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

dt.getMonth(); // => 11:月;实际为1九月份(月份从0开端盘算)

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

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

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

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

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

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

dt.get提姆(Tim)e(); // => 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代表八月,11意味着1四月。

 

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:月;实际为1十一月份(月份从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 to提姆eString() :将Date转换为一个’时分秒’字符串

 

Date日期和岁月对象,JavaScript原生对象之Date对象的习性和方法详解。4.3.6 toLocale提姆(Tim)eString() :将Date转换为一个’时分秒’的地面格式字符串

 

4.3.7 valueOf() :与get提姆e()一样, 再次回到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()); // => 二零一四年18月23日 早晨10:56:11
 :将Date转换为一个’年月日 时分秒’的地点格式字符串

 

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

console.log(dt.toLocaleDateString()); // => 二零一四年1十一月23日
:将Date转换为一个’年月日’的地头格式字符串

 

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

console.log(dt.toLocale提姆eString()); // => 清晨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#的Date提姆e类型转换为Js的Date对象

说明:C#的Date提姆(Tim)e类型通过Json系列化重回给前台的格式为:”\/Date(1419492640000)\/”
。中间的数字,表示Date提姆e的值与开头时间之间的微秒数。

 

示例:

 

后台代码:简单的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#
Date提姆(Tim)e类型转换的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() :返…

题目排查

奉公守法稳定做法,出问题后先自己本地跑了两回测试用例,没有其它问题,先河就足以稳定是开发条件问题。于是乎就看了下小伙伴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对象对日期和岁月的操作只好通过措施。

连带规范

ISO8601标准[参考5]

该标准指定了即使为指定偏移时间就默许为眼前光阴。

亚洲必赢官网 2

[ES5 规范][参考6]

提出了一旦没有点名偏移量,默许偏移量为Z。

亚洲必赢官网 3

[ES6 规范][参考7]

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

亚洲必赢官网 4

//value-飞秒:代表自世界和谐时1970年三月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(8月)到11(1九月)
//day-日:代表一个月底的第几天的整数值,从1从头
//hour-时辰:代表一天中的时辰数的平头值 (24时辰制)
//minute-分钟
//second-秒
//millisecond-毫秒
new Date(year, month, day [, hour, minute, second, millisecond]);

返回值:

经验教训

出于浏览器的出入和不均等,强烈指出不要
使用Date构造函数解析日期字符串(并且Date.parse它们是等价的)。

尽可能选取“YYYY / MM /
DD”作为日期字符串,或者应用时间时分秒的构造函数来布局Date对象,他们得到周边地支持。有了那种格式,所有的小时都是地面的。

只有你驾驭自己在做什么样,否则请防止使用含有连字符号的日期(”YYYY-MM-DD”),唯有较新的浏览器匡助它们。

Date()

{Date} 重回一个代表当地日期和时间的Date对象。

参考

[1]

[2]

[3]

[4]

[5]

[6]

[7]

1 赞 1 收藏
评论

亚洲必赢官网 6

Date() 方法可再次来到当天的日子和岁月。

示例:

复制代码 代码如下:

复制代码 代码如下:

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.set提姆(Tim)e() 就可以运用它了。

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

ECMAScript中的Date类型是初期Java中的Java.util.Date类基础上构建的。为此,Date类型使用来源UTC(Coordinated
Universal
提姆e,国际协调时间)1970年7月1日子夜(零时)开端通过的阿秒数来保存日期。在采纳那种多少存储格式的尺码下,Date类型保存的日子可以准确到1970年七月1日事先或未来的285616年。

返回值:

在意:parse()日期和时间都基于本地时区而非GMT来创设。而UTC()是依照GMT来创立。他们的参数也不一样等。

{Date} 再次回到一个更换后的Date对象。

GMT:世界时,即格林(Green)尼治所在地的业内时间。

示例:

复制代码 代码如下:

复制代码 代码如下:

var d = new 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

console.log(Date.parse(d));  //1379393562000
console.log(Date.UTC(d.getFullYear(), d.getMonth(), d.getDate(),
d.getHours(), d.getMinutes(), d.getSeconds(), d.getMilliseconds())); 
//1379422362020

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

ECMAScript5添加了Data.now()方法,再次回到表示调用那一个措施时的日子和岁月的飞秒数。IE9才初阶援救,但是我们得以因而

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

  • 操作符来把Data对象转换成字符串,得到平等的值。

②month {int} :月份;2位数字。从0开头猜想,0代表11月份、11意味着五月份。

复制代码 代码如下:

③opt_day {int} 可选:号; 2位数字;从1起首臆想,1意味着1号。

var d1 = Date.now();
var d2 = + new Date();

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

console.log(d1);  //1379393793104
console.log(d2);  //1379393793104

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

JavaScript中的日期转换非凡的好奇,不仅会因为参数分化而有差距的诠释结果,而且在挨家挨户浏览器中的表现也黯然失色,如下:

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

复制代码 代码如下:

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

var d1 = new Date(“2012/03/13”);
var d2 = new Date(“2012-03-13”);
var d3 = new Date(“2012-3-13”);

返回值:

console.log(d1);  //Tue Mar 13 2012 00:00:00 GMT+0800 (中国标准时间)
console.log(d2);  //Tue Mar 13 2012 08:00:00 GMT+0800 (中国标准时间)
console.log(d3);  //Tue Mar 13 2012 00:00:00 GMT+0800 (中国标准时间)

{Date} 重返一个变换后的Date对象。

在差距浏览器中的表现参考:

示例:

为了幸免那一个题材,请根据下边的提出:

复制代码 代码如下:

1.坚韧不拔使用 ”YYYY/MM/DD” 的日期字符串格式
2.避免拔取带有连字号的日子字符串格式”YYYY-MM-DD”
3.要指定四位数的年度
4.Chrome浏览器的比其余浏览器能承受更加多的日子字符串,所以只要在Chrome浏览器不成问题,不意味任何浏览器不是问题

var dt = new Date(2014, 11); // 二〇一四年1三月(那里输入的月度数字为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); //
二〇一四年1四月25日(那里输入的月份数字为12,表示第1八个月,跳转到第二年的12月)
console.log(dt); // => {Date}:2015/01/25

越多音讯方可参考:JavaScript and Dates, What a
Mess!和
SO中的议论

3. 属性

get种类措施

无;Date对象对日期和岁月的操作只好通过艺术。

getDate() 从 Date 对象回来一个月尾的某一天 (1 ~ 31)。
getDay() 从 Date 对象回到一周中的某一天 (0 ~ 6)。
getMonth() 从 Date 对象回来月份 (0 ~ 11)。
getFullYear() 从 Date 对象以四位数字再次来到年份。注意不要选拔getYear()。
getHours() 再次来到 Date 对象的钟点 (0 ~ 23)。
getMinutes() 再次来到 Date 对象的分钟 (0 ~ 59)。
getSeconds() 重返 Date 对象的秒数 (0 ~ 59)。
getMilliseconds() 重返 Date 对象的飞秒(0 ~ 999)。
get提姆e() 再次回到 1970 年 1 月 1 日至今的飞秒数。
get提姆(Tim)ezoneOffset() 重返本地时间与格林(Green)威治标准时间 (GMT) 的分钟差。
getUTCDate() 依据世界时从 Date 对象重返月首的一天 (1 ~ 31)。
getUTCDay() 按照世界时从 Date 对象回到周中的一天 (0 ~ 6)。
getUTCMonth() 按照世界时从 Date 对象回来月份 (0 ~ 11)。
getUTCFullYear() 根据世界时从 Date 对象回到四位数的年度。
getUTCHours() 根据世界时再次来到 Date 对象的小时 (0 ~ 23)。
getUTCMinutes() 根据世界时再次回到 Date 对象的分钟 (0 ~ 59)。
getUTCSeconds() 根据世界时重临 Date 对象的分钟 (0 ~ 59)。
getUTCMilliseconds() 依照世界时重返 Date 对象的微秒(0 ~ 999)。

4. 实例方法

set体系措施

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

setDate() 设置 Date 对象中月的某一天 (1 ~ 31)。
setMonth() 设置 Date 对象中月份 (0 ~ 11)。
setFullYear() 设置 Date
对象中的年份(四位数字)。注意不要使用setYear()方法。
setHours() 设置 Date 对象中的小时 (0 ~ 23)。
setMinutes() 设置 Date 对象中的分钟 (0 ~ 59)。
setSeconds() 设置 Date 对象中的分钟 (0 ~ 59)。
setMilliseconds() 设置 Date 对象中的飞秒 (0 ~ 999)。
set提姆(Tim)e() 以阿秒设置 Date 对象。
setUTCDate() 根据世界时设置 Date 对象中月份的一天 (1 ~ 31)。
setUTCMonth() 根据世界时设置 Date 对象中的月份 (0 ~ 11)。
setUTCFullYear() 根据世界时设置 Date 对象中的年份(四位数字)。
setUTCHours() 依据世界时设置 Date 对象中的小时 (0 ~ 23)。
setUTCMinutes() 根据世界时设置 Date 对象中的分钟 (0 ~ 59)。
setUTCSeconds() 按照世界时设置 Date 对象中的分钟 (0 ~ 59)。
setUTC米尔(Mill)iseconds() 依照世界时设置 Date 对象中的毫秒 (0 ~ 999)。

4.1 get方法
4.1.1 getFullYear() :再次回到Date对象的年份值;4位年份。

toString种类措施

4.1.2 getMonth() :重返Date对象的月份值。从0初叶,所以真实月份=重临值+1

toString() 把 Date
对象转换为字符串,toString()总是回到一个用美式乌克兰(克兰)语表明的字符串。
to提姆(Tim)eString() 把 Date 对象的命宫部分更换为字符串。
toDateString() 把 Date 对象的日期部分更换为字符串。
toUTCString() 按照世界时,把 Date 对象转换为字符串。
toLocaleString() 根据地点时间格式,把 Date 对象转换为字符串。
toLocale提姆eString() 依照地点时间格式,把 Date
对象的岁月有些更换为字符串。
toLocaleDateString() 依照地方时间格式,把 Date
对象的日子部分更换为字符串。

4.1.3 getDate() :再次回到Date对象的月份中的日期值;值的限制1~31 。

复制代码 代码如下:

4.1.4 getHours() :再次回到Date对象的小时值。

var d = new Date();

4.1.5 getMinutes() :再次回到Date对象的分钟值。

console.log(d);                      //Tue Sep 17 2013 13:37:04 GMT+0800
(中国标准时间)
console.log(d.toString());           //Tue Sep 17 2013 13:37:04 GMT+0800
(中国标准时间)
console.log(d.to提姆(Tim)eString());       //13:37:04 GMT+0800
(中国标准时间)
console.log(d.toDateString() );      //Tue Sep 17 2013
console.log(d.toUTCString());        //Tue, 17 Sep 2013 05:37:04 GMT
console.log(d.toLocaleString());     //2013年9月17日 下午1:37:04
console.log(d.toLocaleTimeString()); //下午1:37:04
console.log(d.toLocaleDateString()); //2013年9月17日

4.1.6 getSeconds() :再次回到Date对象的秒数值。

专注toLocaleString()体系措施可以吸收参数,来确定根据什么样习惯来输出,参考:MDN

4.1.7 get米尔(Mill)iseconds() :再次来到Date对象的微秒值。

复制代码 代码如下:

4.1.8 getDay()
:重回Date对象的七日中的星期值;0为星期六,1为周五、2为周五,依此类推

var d = new Date();

4.1.9 get提姆(Tim)e() :再次来到Date对象与’1970/01/01
00:00:00’之间的皮秒值(香江时间的时区为东8区,起源时间实在为:’1970/01/01
08:00:00′) 。

console.log(d.toLocaleString(“ko-KR”));  //2013년 9월 17일 오후
1:48:24

示例:

你或许感兴趣的篇章:

  • 恢宏JS
    Date对象时间格式化功用的小例子
  • JavaScript Date对象详解
  • 详解JavaScript对Date对象的操作问题(生成一个倒数7天的数组)
  • javascript转换日期字符串为Date日期对象的点子
  • 浅谈JavaScript中Date(日期对象),Math对象
  • 浅谈JavaScript
    Date日期和岁月对象
  • JavaScript
    中Date对象的格式化代码方法汇总

复制代码 代码如下:

dt.getFullYear(); // => 2014:年
dt.getMonth(); // => 11:月;实际为1十二月份(月份从0起初估算)
dt.getDate(); // => 25:日
dt.getHours(); // => 15:时
dt.getMinutes(); // => 30:分
dt.getSeconds(); // => 40:秒
dt.getMilliseconds(); // => 333:毫秒
dt.getDay(); // => 4:星期几的值
dt.get提姆e(); // => 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象征3月,11象征1九月。

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 set米尔iseconds(msec) :设置Date对象的飞秒值。

示例:

复制代码 代码如下:

var dt = new Date();
dt.setFullYear(2014); // => 2014:年
dt.setMonth(11); // => 11:月;实际为17月份(月份从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 to提姆eString() :将Date转换为一个’时分秒’字符串

4.3.6 toLocale提姆(Tim)eString() :将Date转换为一个’时分秒’的地点格式字符串

4.3.7 valueOf() :与get提姆e()一样, 重返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()); // => 二〇一四年1七月23日 早上10:56:11 
:将Date转换为一个’年月日 时分秒’的地面格式字符串
console.log(dt.toDateString()); // => Tue Dec 23 2014
:将Date转换为一个’年月日’字符串
console.log(dt.toLocaleDateString()); // => 二零一四年1二月23日
:将Date转换为一个’年月日’的本土格式字符串
console.log(dt.to提姆eString()); // => 22:56:11 GMT+0800
(中国标准时间) :将Date转换为一个’时分秒’字符串
console.log(dt.toLocale提姆(Tim)eString()); // => 早晨10:56:11
:将Date转换为一个’时分秒’的地头格式字符串
console.log(dt.valueOf()); // => 再次回到Date对象与’1970/01/01
00:00:00’之间的阿秒值(香港(Hong Kong)时间的时区为东8区,起源时间莫过于为:’1970/01/01
08:00:00′)

5. 静态方法

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’之间的微秒值(东京(Tokyo)时间的时区为东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!)

6. 实际操作

6.1 C#的Date提姆e类型转换为Js的Date对象
说明:C#的Date提姆e类型通过Json种类化重返给前台的格式为:”\/Date(1419492640000)\/”
。中间的数字,表示Date提姆e的值与发轫时间里面的阿秒数。

示例:

后台代码:简单的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#
Date提姆e类型转换的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

你或许感兴趣的篇章:

  • 壮大JS
    Date对象时间格式化功效的小例子
  • JavaScript Date对象详解
  • 详解JavaScript对Date对象的操作问题(生成一个尾数7天的数组)
  • JavaScript原生对象之Date对象的习性和办法详解
  • javascript转换日期字符串为Date日期对象的法门
  • 浅谈JavaScript中Date(日期对象),Math对象
  • JavaScript
    中Date对象的格式化代码方法汇总
网站地图xml地图