Date对象

60次阅读

共计 4234 个字符,预计需要花费 11 分钟才能阅读完成。

Date 对象

Date 对象是 JavaScript 原生的时间库。它以国际标准时间(UTC)1970 年 1 月 1 日 00:00:00 作为时间的零点,可以表示的时间范围是前后各 1 亿天(单位为毫秒)。

普通函数的用法 Date(不管有无参数,返回当前时间字符串)
Date(2000, 1, 1)
// “Tue Dec 01 2015 09:34:43 GMT+0800 (CST)
构造函数的用法
日期的运算
静态方法
Date.now()
Date.parse()
Date.UTC()
实例方法
Date.prototype.valueOf()
to 类方法
get 类方法
set 类方法
参考链接

1. 构造函数的用法
作为构造函数时,Date 对象可以接受多种格式的参数,返回一个该参数对应的时间实例。

var today = new Date();
Date 实例有一个独特的地方。其他对象求值的时候,都是默认调用.valueOf()方法,但是 Date 实例求值的时候,默认调用的是 toString()方法。这导致对 Date 实例求值,返回的是一个字符串,代表该实例对应的时间。

1.1 参数
(1)参数为时间零点开始计算的毫秒数(正负都可)
(2)(多个整数 至少两个年,月,日,时,分,秒,毫秒)
月 0 -11 可正负的日期进退位 日期为 0 则为上个月最后一天
(3)只要是能被 Date.parse()方法解析的字符串,都可以当作参数。

new Date(‘2013-2-15’)
new Date(‘2013/2/15’)
new Date(’02/15/2013′)
new Date(‘2013-FEB-15’)
new Date(‘FEB, 15, 2013’)
new Date(‘FEB 15, 2013’)
new Date(‘February, 15, 2013’)
new Date(‘February 15, 2013’)
new Date(’15 Feb 2013′)
new Date(’15, February, 2013′)
// Fri Feb 15 2013 00:00:00 GMT+0800 (CST
2. 日期的运算
减 毫秒
加 字符串
var d1 = new Date(2000, 2, 1);
var d2 = new Date(2000, 3, 1);

d2 – d1
// 2678400000
d2 + d1
// “Sat Apr 01 2000 00:00:00 GMT+0800 (CST)Wed Mar 01 2000 00:00:00 GMT+0800 (CST)
3. 静态方法(都返回毫秒)
3.1Date.now()毫秒
3.2Date.parse()

Date.parse 方法用来解析日期字符串,返回该时间距离时间零点(1970 年 1 月 1 日 00:00:00)的毫秒数。
rse(‘Aug 9, 1995’)
Date.parse(‘January 26, 2011 13:51:50’)
Date.parse(‘Mon, 25 Dec 1995 13:30:00 GMT’)
Date.parse(‘Mon, 25 Dec 1995 13:30:00 +0430’)
Date.parse(‘2011-10-10’)
Date.parse(‘2011-10-10T14:48:00’)
上面的日期字符串都可以解析。

如果解析失败,返回 NaN。

Date.parse(‘xxx’) // NaN
3.3Date.UTC()
Date.UTC 方法接受年、月、日等变量作为参数,返回该时间距离时间零点(1970 年 1 月 1 日 00:00:00 UTC)的毫秒数。

// 格式
Date.UTC(year, month[, date[, hrs[, min[, sec[, ms]]]]])

// 用法
Date.UTC(2011, 0, 1, 2, 3, 4, 567)
// 1293847384567

Date.UTC 方法的参数,会被解释为 UTC 时间(世界标准时间),Date 构造函数的参数会被解释为当前时区的时间

4 实例方法
除了 valueOf 和 toString,可以分为以下三类。

to 类:从 Date 对象返回一个字符串,表示指定的时间。
get 类:获取 Date 对象的日期和时间。
set 类:设置 Date 对象的日期和时间。

4.1Date.prototype.valueOf()
var d = new Date();

d.valueOf() // 1362790014817
d.getTime() // 136270014817
4.2to 类方法(格式化日期)
4.2.1tostring
4.2.2Date.prototype.toUTCString()

toUTCString 方法返回对应的 UTC 时间,也就是比北京时间晚 8 个小时。
4.2.3Date.prototype.toISOString()

toISOString 方法返回对应时间的 ISO8601 写法
var d = new Date(2013, 0, 1);

d.toISOString()
// “2012-12-31T16:00:00.000Z”
4.2.4toJSON 方法返回一个符合 JSON 格式的 ISO 日期字符串,与 toISOString 方法的返回结果完全相同。

var d = new Date(2013, 0, 1);

d.toJSON()
// “2012-12-31T16:00:00.000Z”
(5)Date.prototype.toDateString()

toDateString 方法返回日期字符串(不含小时、分和秒)。

var d = new Date(2013, 0, 1);
d.toDateString() // “Tue Jan 01 2013”
(6)Date.prototype.toTimeString()

toTimeString 方法返回时间字符串(不含年月日)。

var d = new Date(2013, 0, 1);
d.toTimeString() // “00:00:00 GMT+0800

(7)本地时间

以下三种方法,可以将 Date 实例转为表示本地时间的字符串。

Date.prototype.toLocaleString():完整的本地时间。
Date.prototype.toLocaleDateString():本地日期(不含小时、分和秒)。
Date.prototype.toLocaleTimeString():本地时间(不含年月日)。

这三个方法都有两个可选的参数。

dateObj.toLocaleString([locales[, options]])
dateObj.toLocaleDateString([locales[, options]])
dateObj.toLocaleTimeString([locales[, options]])

var d = new Date(2013, 0, 1);

d.toLocaleString(‘en-US’) // “1/1/2013, 12:00:00 AM”
d.toLocaleString(‘zh-CN’) // “2013/1/1 上午 12:00:00”

var d = new Date(2013, 0, 1);

// 时间格式
// 下面的设置是,星期和月份为完整文字,年份和日期为数字
d.toLocaleDateString(‘en-US’, {
weekday: ‘long’,
year: ‘numeric’,
month: ‘long’,
day: ‘numeric’
})
// “Tuesday, January 1, 2013”

// 指定时区
d.toLocaleTimeString(‘en-US’, {
timeZone: ‘UTC’,
timeZoneName: ‘short’
})
// “4:00:00 PM UTC”
4.3get 类方法
Date 对象提供了一系列 get* 方法,用来获取实例对象某个方面的值。

getTime():返回实例距离 1970 年 1 月 1 日 00:00:00 的毫秒数,等同于 valueOf 方法。
getDate():返回实例对象对应每个月的几号(从 1 开始)。
getDay():返回星期几,星期日为 0,星期一为 1,以此类推。
getFullYear():返回四位的年份。
getMonth():返回月份(0 表示 1 月,11 表示 12 月)。
getHours():返回小时(0-23)。
getMilliseconds():返回毫秒(0-999)。
getMinutes():返回分钟(0-59)。
getSeconds():返回秒(0-59)。
getTimezoneOffset():返回当前时间与 UTC 的时区差异,以分钟表示,返回结果考虑到了夏令时因素。

上面这些 get* 方法返回的都是当前时区的时间,Date 对象还提供了这些方法对应的 UTC 版本,用来返回 UTC 时间。

getUTCDate()
getUTCFullYear()
getUTCMonth()
getUTCDay()
getUTCHours()
getUTCMinutes()
getUTCSeconds()
getUTCMilliseconds()

4.4set 类方法

Date 对象提供了一系列 set* 方法,用来设置实例对象的各个方面。

setDate(date):设置实例对象对应的每个月的几号(1-31),返回改变后毫秒时间戳。
setFullYear(year [, month, date]):设置四位年份。
setHours(hour [, min, sec, ms]):设置小时(0-23)。
setMilliseconds():设置毫秒(0-999)。
setMinutes(min [, sec, ms]):设置分钟(0-59)。
setMonth(month [, date]):设置月份(0-11)。
setSeconds(sec [, ms]):设置秒(0-59)。
setTime(milliseconds):设置毫秒时间戳。

没有 setDay 方法,因为星期几是计算出来的,而不是设置

set 类方法和 get 类方法,可以结合使用,得到相对时间。

var d = new Date();

// 将日期向后推 1000 天
d.setDate(d.getDate() + 1000);
// 将时间设为 6 小时后
d.setHours(d.getHours() + 6);
// 将年份设为去年
d.setFullYear(d.getFullYear() – 1);

set* 系列方法除了 setTime(),都有对应的 UTC 版本,即设置 UTC 时区的时间。

setUTCDate()
setUTCFullYear()
setUTCHours()
setUTCMilliseconds()
setUTCMinutes()
setUTCMonth()
setUTCSeconds()

正文完
 0