1. 介紹:闡述 Date 對(duì)象宵膨。
Date對(duì)象架谎,是操作日期和時(shí)間的對(duì)象。Date對(duì)象對(duì)日期和時(shí)間的操作只能通過方法辟躏。
2. 構(gòu)造函數(shù):介紹 Date 對(duì)象的構(gòu)造函數(shù)new Date()幾種方式谷扣。
2.1 new Date() :返回當(dāng)前的本地日期和時(shí)間
--例子:
var dt = new Date();
console.log(dt); // => 返回一個(gè)表示本地日期和時(shí)間的Date對(duì)象
2.2 new Date(milliseconds) :把毫秒數(shù)轉(zhuǎn)換為Date對(duì)象
+參數(shù):
①milliseconds {int} :毫秒數(shù);表示從'1970/01/01 00:00:00'為起點(diǎn)捎琐,開始疊加的毫秒數(shù)会涎。
+返回值:
{Date} 返回一個(gè)疊加后的Date對(duì)象。
--例子:
var dt = new Date(1000 * 60 * 1); // 前進(jìn)1分鐘的毫秒數(shù)
console.log(dt); // => {Date}:1970/01/01 08:01:00
dt = new Date(-1000 * 60 * 1); // 倒退1分鐘的毫秒數(shù)
console.log(dt); // => {Date}:1970/01/01 07:59:00
2.3 new Date(dateStr) :把字符串轉(zhuǎn)換為Date對(duì)象
+參數(shù):
①dateStr {string} :可轉(zhuǎn)換為Date對(duì)象的字符串(可省略時(shí)間)瑞凑;字符串的格式主要有兩種:
1) yyyy/MM/dd HH:mm:ss (推薦):若省略時(shí)間末秃,返回的Date對(duì)象的時(shí)間為 00:00:00。
2) yyyy-MM-dd HH:mm:ss :若省略時(shí)間籽御,返回的Date對(duì)象的時(shí)間為 08:00:00(加上本地時(shí)區(qū))练慕。若不省略時(shí)間惰匙,此字符串在IE中會(huì)轉(zhuǎn)換失敗!
+返回值:
{Date} 返回一個(gè)轉(zhuǎn)換后的Date對(duì)象。
--例子:
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區(qū)的時(shí)區(qū))
dt = new Date('2014-12-25 12:00:00'); // yyyy-MM-dd HH:mm:ss (注意:此轉(zhuǎn)換方式在IE中會(huì)報(bào)錯(cuò)铃将!)
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) :把年月日徽曲、時(shí)分秒轉(zhuǎn)換為Date對(duì)象
? +參數(shù):
①year {int} :年份;4位數(shù)字麸塞。如:1999秃臣、2014
②month {int} :月份;2位數(shù)字哪工。從0開始計(jì)算奥此,0表示1月份、11表示12月份雁比。
③opt_day {int} 可選:號(hào)稚虎; 2位數(shù)字;從1開始計(jì)算偎捎,1表示1號(hào)蠢终。
④opt_hours {int} 可選:時(shí);2位數(shù)字茴她;取值0~23寻拂。
⑤opt_minutes {int} 可選:分;2位數(shù)字丈牢;取值0~59祭钉。
⑥opt_seconds {int} 可選:秒;2未數(shù)字己沛;取值0~59慌核。
⑦opt_milliseconds {int} 可選:毫秒;取值0~999申尼。
+返回值:
{Date} 返回一個(gè)轉(zhuǎn)換后的Date對(duì)象垮卓。
---例子:
var dt = new Date(2014, 11); // 2014年12月(這里輸入的月份數(shù)字為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點(diǎn)30分40秒
console.log(dt); // => {Date}:2014/12/25 15:30:40
dt = new Date(2014, 12, 25); // 2014年13月25日(這里輸入的月份數(shù)字為12,表示第13個(gè)月师幕,跳轉(zhuǎn)到第二年的1月)
console.log(dt); // => {Date}:2015/01/25
3. 實(shí)例方法:介紹 Date 對(duì)象的get粟按、set等實(shí)例方法。
Date對(duì)象的實(shí)例方法主要分為2種形式:本地時(shí)間和UTC時(shí)間们衙。同一個(gè)方法钾怔,一般都會(huì)有此2種時(shí)間格式操作(方法名帶UTC的,就是操作UTC時(shí)間)蒙挑,這里主要介紹對(duì)本地時(shí)間的操作宗侦。
<!-- 拓展 UTC:是協(xié)調(diào)世界時(shí)間? 了解就行-->
協(xié)調(diào)世界時(shí)(英:Coordinated Universal Time ,法:Temps Universel Coordonné)忆蚀,又稱世界統(tǒng)一時(shí)間矾利,世界標(biāo)準(zhǔn)時(shí)間姑裂,國(guó)際協(xié)調(diào)時(shí)間。英文(CUT)和法文(TUC)的縮寫不同男旗,作為妥協(xié)舶斧,簡(jiǎn)稱UTC。
協(xié)調(diào)世界時(shí)是以原子時(shí)秒長(zhǎng)為基礎(chǔ)察皇,在時(shí)刻上盡量接近于世界時(shí)的一種時(shí)間計(jì)量系統(tǒng)茴厉。
中國(guó)大陸采用ISO 8601-1988的《數(shù)據(jù)元和交換格式信息交換日期和時(shí)間表示法》(GB/T 7408-1994)稱之為國(guó)際協(xié)調(diào)時(shí)間,現(xiàn)行標(biāo)準(zhǔn)號(hào)為GB/T 7408-2005什荣,2005-10-01實(shí)施矾缓,代替原來的GB/T 7408-1994。
中國(guó)臺(tái)灣采用CNS 7648的《資料元及交換格式–資訊交換–日期及時(shí)間的表示法》(與ISO 8601類似)稱之為世界統(tǒng)一時(shí)間稻爬。
<!--? -->
3.1 get方法
3.1.1 getFullYear() :返回Date對(duì)象的年份值嗜闻;4位年份。
3.1.2 getMonth() :返回Date對(duì)象的月份值桅锄。從0開始琉雳,所以真實(shí)月份=返回值+1 。
3.1.3 getDate() :返回Date對(duì)象的月份中的日期值友瘤;值的范圍1~31 翠肘。
3.1.4 getHours() :返回Date對(duì)象的小時(shí)值。
3.1.5 getMinutes() :返回Date對(duì)象的分鐘值商佑。
3.1.6 getSeconds() :返回Date對(duì)象的秒數(shù)值锯茄。
3.1.7 getMilliseconds() :返回Date對(duì)象的毫秒值。
3.1.8 getDay() :返回Date對(duì)象的一周中的星期值茶没;0為星期天,1為星期一晚碾、2為星期二抓半,依此類推
3.1.9 getTime() :返回Date對(duì)象與'1970/01/01 00:00:00'之間的毫秒值(北京時(shí)間的時(shí)區(qū)為東8區(qū),起點(diǎn)時(shí)間實(shí)際為:'1970/01/01 08:00:00') 格嘁。
---例子:
dt.getFullYear(); // => 2014:年
dt.getMonth(); // => 11:月笛求;實(shí)際為12月份(月份從0開始計(jì)算)
dt.getDate(); // => 25:日
dt.getHours(); // => 15:時(shí)
dt.getMinutes(); // => 30:分
dt.getSeconds(); // => 40:秒
dt.getMilliseconds(); // => 333:毫秒
dt.getDay(); // => 4:星期幾的值
dt.getTime(); // => 1419492640333 :返回Date對(duì)象與'1970/01/01 00:00:00'之間的毫秒值(北京時(shí)間的時(shí)區(qū)為東8區(qū),起點(diǎn)時(shí)間實(shí)際為:'1970/01/01 08:00:00')
3.2 set方法
3.2.1 setFullYear(year, opt_month, opt_date) :設(shè)置Date對(duì)象的年份值糕簿;4位年份探入。
3.2.2 setMonth(month, opt_date) :設(shè)置Date對(duì)象的月份值。0表示1月懂诗,11表示12月蜂嗽。
3.2.3 setDate(date) :設(shè)置Date對(duì)象的月份中的日期值;值的范圍1~31 殃恒。
3.2.4 setHours(hour, opt_min, opt_sec, opt_msec) :設(shè)置Date對(duì)象的小時(shí)值植旧。
3.2.5 setMinutes(min, opt_sec, opt_msec) :設(shè)置Date對(duì)象的分鐘值辱揭。
3.2.6 setSeconds(sec, opt_msec) :設(shè)置Date對(duì)象的秒數(shù)值。
3.2.7 setMilliseconds(msec) :設(shè)置Date對(duì)象的毫秒值病附。
---例子:
var dt = new Date();
dt.setFullYear(2014); // => 2014:年
dt.setMonth(11); // => 11:月问窃;實(shí)際為12月份(月份從0開始計(jì)算)
dt.setDate(25); // => 25:日
dt.setHours(15); // => 15:時(shí)
dt.setMinutes(30); // => 30:分
dt.setSeconds(40); // => 40:秒
dt.setMilliseconds(333); // => 333:毫秒
console.log(dt); // =>? 2014年12月25日 15點(diǎn)30分40秒 333毫秒
3.3 其他方法
3.3.1 toString() :將Date轉(zhuǎn)換為一個(gè)'年月日 時(shí)分秒'字符串
3.3.2 toLocaleString() :將Date轉(zhuǎn)換為一個(gè)'年月日 時(shí)分秒'的本地格式字符串
3.3.3 toDateString() :將Date轉(zhuǎn)換為一個(gè)'年月日'字符串
3.3.4 toLocaleDateString() :將Date轉(zhuǎn)換為一個(gè)'年月日'的本地格式字符串
3.3.5 toTimeString() :將Date轉(zhuǎn)換為一個(gè)'時(shí)分秒'字符串
3.3.6 toLocaleTimeString() :將Date轉(zhuǎn)換為一個(gè)'時(shí)分秒'的本地格式字符串
3.3.7 valueOf() :與getTime()一樣, 返回Date對(duì)象與'1970/01/01 00:00:00'之間的毫秒值(北京時(shí)間的時(shí)區(qū)為東8區(qū)完沪,起點(diǎn)時(shí)間實(shí)際為:'1970/01/01 08:00:00')
--例子:
var dt = new Date();
console.log(dt.toString()); // => Tue Dec 23 2014 22:56:11 GMT+0800 (中國(guó)標(biāo)準(zhǔn)時(shí)間) :將Date轉(zhuǎn)換為一個(gè)'年月日 時(shí)分秒'字符串
console.log(dt.toLocaleString()); // => 2014年12月23日 下午10:56:11? :將Date轉(zhuǎn)換為一個(gè)'年月日 時(shí)分秒'的本地格式字符串
console.log(dt.toDateString()); // => Tue Dec 23 2014 :將Date轉(zhuǎn)換為一個(gè)'年月日'字符串
console.log(dt.toLocaleDateString()); // => 2014年12月23日 :將Date轉(zhuǎn)換為一個(gè)'年月日'的本地格式字符串
console.log(dt.toTimeString()); // => 22:56:11 GMT+0800 (中國(guó)標(biāo)準(zhǔn)時(shí)間) :將Date轉(zhuǎn)換為一個(gè)'時(shí)分秒'字符串
console.log(dt.toLocaleTimeString()); // => 下午10:56:11 :將Date轉(zhuǎn)換為一個(gè)'時(shí)分秒'的本地格式字符串
console.log(dt.valueOf()); // => 返回Date對(duì)象與'1970/01/01 00:00:00'之間的毫秒值(北京時(shí)間的時(shí)區(qū)為東8區(qū)域庇,起點(diǎn)時(shí)間實(shí)際為:'1970/01/01 08:00:00')
4. 靜態(tài)方法:介紹 Date 對(duì)象的靜態(tài)方法:Date.now()、 Date.parse()等覆积。
4.1 Date.now()
說明:返回當(dāng)前日期和時(shí)間的Date對(duì)象與'1970/01/01 00:00:00'之間的毫秒值(北京時(shí)間的時(shí)區(qū)為東8區(qū)较剃,起點(diǎn)時(shí)間實(shí)際為:'1970/01/01 08:00:00')
參數(shù):無
返回值:
{int} :當(dāng)前時(shí)間與起始時(shí)間之間的毫秒數(shù)。
示例:
1.console.log(Date.now()); // => 1419431519276
4.2 Date.parse(dateStr)
說明:把字符串轉(zhuǎn)換為Date對(duì)象 技健,然后返回此Date對(duì)象與'1970/01/01 00:00:00'之間的毫秒值(北京時(shí)間的時(shí)區(qū)為東8區(qū)写穴,起點(diǎn)時(shí)間實(shí)際為:'1970/01/01 08:00:00')
參數(shù):
①dateStr {string} :可轉(zhuǎn)換為Date對(duì)象的字符串(可省略時(shí)間);字符串的格式主要有兩種:
1) yyyy/MM/dd HH:mm:ss (推薦):若省略時(shí)間雌贱,返回的Date對(duì)象的時(shí)間為 00:00:00啊送。
2) yyyy-MM-dd HH:mm:ss :若省略時(shí)間,返回的Date對(duì)象的時(shí)間為 08:00:00(加上本地時(shí)區(qū))欣孤。若不省略時(shí)間馋没,此字符串在IE中返回NaN(非數(shù)字)!
返回值:
{int} 返回轉(zhuǎn)換后的Date對(duì)象與起始時(shí)間之間的毫秒數(shù)。
示例:
1. console.log(Date.parse('2014/12/25 12:00:00')); // => 1419480000000
2. console.log(Date.parse('2014-12-25 12:00:00')); // => 1419480000000(注意:此轉(zhuǎn)換方式在IE中返回NaN降传!)
5. 實(shí)際操作:日歷篷朵、倒計(jì)時(shí)搶購(gòu)