Date对象

2018-11-18  本文已影响0人  花差花差小宝

1. 介绍:阐述 Date 对象。

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

2. 构造函数:介绍 Date 对象的构造函数new Date()几种方式。

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

--例子:

var dt = new Date();

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

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

+参数:

①milliseconds {int} :毫秒数;表示从'1970/01/01 00: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

3. 实例方法:介绍 Date 对象的get、set等实例方法。

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

<!-- 拓展 UTC:是协调世界时间  了解就行-->

协调世界时(英:Coordinated Universal Time ,法:Temps Universel Coordonné),又称世界统一时间,世界标准时间,国际协调时间。英文(CUT)和法文(TUC)的缩写不同,作为妥协,简称UTC。

协调世界时是以原子时秒长为基础,在时刻上尽量接近于世界时的一种时间计量系统。

中国大陆采用ISO 8601-1988的《数据元和交换格式信息交换日期和时间表示法》(GB/T 7408-1994)称之为国际协调时间,现行标准号为GB/T 7408-2005,2005-10-01实施,代替原来的GB/T 7408-1994。

中国台湾采用CNS 7648的《资料元及交换格式–资讯交换–日期及时间的表示法》(与ISO 8601类似)称之为世界统一时间。

<!--  -->

3.1 get方法

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

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

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

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

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

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

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

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

3.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')

3.2 set方法

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

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

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

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

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

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

3.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毫秒

3.3 其他方法

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

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

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

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

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

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

3.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')

4. 静态方法:介绍 Date 对象的静态方法:Date.now()、 Date.parse()等。

4.1 Date.now()

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

参数:无

返回值:

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

示例:

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

4.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对象与起始时间之间的毫秒数。

示例:

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

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

5. 实际操作:日历、倒计时抢购

上一篇 下一篇

猜你喜欢

热点阅读