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

  要创建一个日期对象,使用new操作符合Date构造函数即可。

var now = new Date();

  在调用Date构造函数而不传参的情况下,新创建的对象自动获取当前日期和时间。如果想根据特定的日期和时间创建日期对象,必须传入表示该日期的毫秒数(1970年1月1日0时至该日期止经过的毫秒数)。

  

  ECMAScript提供了两个方法:Date.parse()和Date.UTC()。

  Date.parse()

  Date.parse()方法接收一个表示日期的字符串参数,然后尝试根据这个字符串返回相应日期的毫秒数。ECMA-262没有定义Date.parse()应该支持哪种日期格式,因此这个方法的行为因实现而异。将地区设置为美国的浏览器通常都接受下列日期格式:

  ♦ "月/日/年",如9/7/2017;

  ♦ "英文月名 日,年",如January 12,2004;

  ♦ "英文星期几英文月名 日 年 时:分:秒 时区",如Thur September 7 2017 00:00:00 GMT-0700。

  ♦ ISO 8601扩展格式YYYY-MM-DDTHH:mm:ss.sssZ(例如 2017-09-07T00:00:00)。只有兼容ECMAScript 5的实现支持这种格式。

  例如,要为2017年9月7日创建一个日期对象,可以使用下面的代码:

var someDate = new Date(Date.parse("September 7,2017"));

  如果传入Date.parse()方法的字符串不能表示日期,那么它会返回NaN。实际上,如果直接将表示日期的字符串传递给Date构造函数,也会在后台调用Date.parse()。例如:

var someDate = new Date("September 7,2017");

  

  Date.UTC()

  Date.UTC()方法同样也返回表示日期的毫秒数,但它与Date.parse()在构建值时使用不同的信息。Date.UTC()的参数分别是年份、基于0的月份(一月是0,二月是1)、月中的哪一天(1到31)、小时数(0到23)、分钟、秒以及毫秒数。在这些参数中,只有前两个参数(年和月)是必需的。如果没有提供月中的天数,则假设天数为1;如果省略其他参数,则统统假设为0。

//GMT时间2000年1月1日午夜零时
var y2k = new Date(Date.UTC(2000,0)); //GMT时间2005年5月5日下午5:55:55
var allFives = new Date(Date.UTC(2005,4,5,17,55,55));

  跟Date.parse()一样,Date构造函数也会模仿Date.UTC(),但有一点明显不同;日期和时间都基于本地时区而非GMT创建。

  ECMAScript 5添加了Date.now()方法,返回表示调用这个方法时的日期和时间的毫秒数。这个方法简化了使用Date对象分析代码的工作。

//取得开始时间
var start = Date.now(); //调用函数
doSomething(); //取得停止时间
var stop = Date.now(),result = stop - start;

  支持Date.now()方法的浏览器包括IE9+、Firefox 3+、Safari 3+、Opera 10.5和Chrome。在不支持它的浏览器中,使用+操作符获取Date对象的时间戳,也可以达到同样的目的。

//取得开始时间
var start = +new Date(); //调用函数
doSomething(); //取得停止时间
var stop = +new Date(),result = stop - start;

  日期格式化方法

  Date类型还有一些专门用于将日期格式化为字符串的方法,这些方法如下:

  ♦ toDateString()——以特定于实现的格式显示星期几、月、日和年;

  ♦ toTimeString()——以特定于实现的格式显示时、分、秒和时区;

  ♦ toLocaleDateString()——以特定于地区的格式显示星期几、月、日和年;

  ♦ toLocaleTimeString()——以特定于实现的格式显示时、分、秒;

  ♦ toUTCString()——以特定于实现的格式完整的UTC日期。

  Date类型的方法

  ♦ getTime():返回表示日期的毫秒数;与valueOf()方法返回的值相同

  ♦ setTime(毫秒):一毫秒数设置日期,会改变整个日期

  ♦ getFullYear():取得4位数的年份

  ♦ getUTCFullYear():返回URC日期的4位数年份

  ♦ setFullYear(年):设置日期的年份。传入的年份值必须是4位数字。

  ♦ setUTCFullYear(年):设置UTC日期的年份。传入的年份值必须是4位数字。

  ♦ getMonth():返回日期中的月份,其中0表示一月,11表示十二月。

  ♦ getUTCMonth():返回UTC日期中的月份,其中0表示一月,11表示十二月。

  ♦ setMonth(月):设置日期的月份。传入的月份值必须大于0,超过11则增加年份

  ♦ setUTCMonth(月):设置UTC日期的月份。传入的月份值必须大于0,超过11则增加年份

  ♦ getDate():返回日期月份中的天数(1到31)

  ♦ getUTCDate():返回UTC日期月份中的天数(1到31)

  ♦ setDate(日):设置日期月份中的天数。如果传入的值超过了该月中应有的天数,则增加月份。

  ♦ setUTCDate(日):设置UTC日期月份中的天数。如果传入的值超过了该月中应有的天数,则增加月份。

  ♦ getDay():返回日期中星期的星期几(其中0表示星期日,6表示星期六)

  ♦ getUTCDay():返回UTC日期中星期的星期几(其中0表示星期日,6表示星期六)

  ♦ getHours():返回日期中的小时数(0到23)

  ♦ getUTCHours():返回UTC日期中的小时数(0到23)

  ♦ setHours(时):设置日期中的小时数。传入的值超过了23则增加月份中的天数

  ♦ setUTCHours(时):设置UTC日期中的小时数。传入的值超过了23则增加月份中的天数

  ♦ getMinutes():返回日期中的分钟数(0到59)

  ♦ getUTCMinutes():返回UTC日期中的分钟数(0到59)

  ♦ setMinutes(分):设置日期中的分钟数。传入的值超过59则增加小时数

  ♦ setUTCMinutes(分):设置UTC日期中的分钟数。传入的值超过59则增加小时数

  ♦ getSeconds():返回日期中的秒数(0到59)

  ♦ getUTCSeconds():返回UTC日期中的秒数(0到59)

  ♦ setSeconds(秒):设置日期中的秒数。传入的值超过59则增加分钟数

  ♦ setUTCSeconds(秒):设置UTC日期中的秒数。传入的值超过59则增加分钟数

  ♦ getMilliseconds():返回日期中的毫秒数

  ♦ getUTCMilliseconds():返回UTC日期中的毫秒数

  ♦ setMilliseconds(毫秒):设置日期中的毫秒数

  ♦ setUTCMilliseconds(毫秒):设置UTC日期中的毫秒数

  ♦ getTimezoneOffset():返回本地时间与UTC时间相差的分钟数。例如,美国东部标准时间返回300;中国标准时间返回-480。

JavaScript中的Date类型的更多相关文章

  1. JavaScript中判断对象类型方法大全1

    我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...

  2. JavaScript中判断对象类型的种种方法

    我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...

  3. 转 JavaScript中判断对象类型的种种方法

    我们知道,JavaScript中检测对象类型的运算符有:typeof.instanceof,还有对象的constructor属性: 1) typeof 运算符 typeof 是一元运算符,返回结果是一 ...

  4. JavaScript中两种类型的全局对象/函数【转】

    Snandy Stop, thinking is the essence of progress. JavaScript中两种类型的全局对象/函数 这里所说的JavaScript指浏览器环境中的包括宿 ...

  5. JavaScript中判断变量类型最简洁的实现方法以及自动类型转换(#################################)

    这篇文章主要介绍了JavaScript中判断整字类型最简洁的实现方法,本文给出多个判断整数的方法,最后总结出一个最短.最简洁的实现方法,需要的朋友可以参考下 我们知道JavaScript提供了type ...

  6. javaScript中Number数字类型方法入门

    前言 Number和Math都属于JavaScript中的内置对象,Number数字类型作为基础数据类型,我们在开发过程中会经常用到,包括数字精度的格式化,还有字符串转换成数字等操作. Number数 ...

  7. 向mysql中插入Date类型的数据

    先看数据库表的定义 date字段为sql.date类型.我要向其中插入指定的日期和当前日期. 一.插入当前日期 思路:先获取当前系统,在将当前系统时间转换成sql类型的时间,然后插入数据库.代码如下 ...

  8. JavaScript高级编程——Date类型

    JavaScript高级编程——Date类型 <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml" ...

  9. es中的date类型

    JSON中没有date类型,es中的date可以由下面3种方式表示: ①格式化的date字符串,例如"2018-01-01"或者"2018-01-01 12:00:00& ...

随机推荐

  1. c版http服务器 shttpd-1.38 vs2013

    有个项目,本来是外网的.要做一个局域网版本. 项目启动就获取一大堆http的数据.考虑到可以提供http服务的软件虽然多,但是多要安装这样那样的软件,还要配置环境或者配置资源等问题. 发布的时候给人一 ...

  2. Quick-Cocos2dx-Community_3.6.3_Release 编译时libtiff.lib 无法解析

    Quick-Cocos2dx-Community_3.6.3_Release 使用VS2012编译,报错: libtiff.lib lnk2001 无法解析的外部符号 ltod3 类似于上面这种,刚才 ...

  3. Remmarguts' Date(POJ2449+最短路+A*算法)

    题目链接:http://poj.org/problem?id=2449 题目: 题意:求有向图两点间的k短路. 思路:最短路+A*算法 代码实现如下: #include <set> #in ...

  4. HDU 1284 钱币兑换问题 (dp)

    题目链接 Problem Description 在一个国家仅有1分,2分,3分硬币,将钱N兑换成硬币有很多种兑法.请你编程序计算出共有多少种兑法.   Input 每行只有一个正整数N,N小于327 ...

  5. 【转】使用SQL语句创建和删除约束

    转自http://blog.csdn.net/hamber_bao/article/details/6504905 约束的目的就是确保表中的数据的完整性. 常用的约束类型如下: 主键约束:(Prima ...

  6. copy_from_user分析

    前言 copy_from_user函数的目的是从用户空间拷贝数据到内核空间,失败返回没有被拷贝的字节数,成功返回0.它内部的实现当然不仅仅拷贝数据,还需要考虑到传入的用户空间地址是否有效,比如地址是不 ...

  7. gnu app url[web][5星]

    http://www.gnu.org/software/software.zh-cn.html http://linux.chinaunix.net/news/2010/12/07/1175310.s ...

  8. Nginx集群配置与redis的session共享策略

    一.什么是Nginx? Nginx (engine x) 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP服务器.Nginx是由伊戈尔·赛索耶夫为俄罗斯访问量第二的Ramb ...

  9. FineReport——JS二次开发(下拉框)

    下拉框显示多列时,输入的内容检索的内容为显示值整行数据,而不是实际值. 下拉框选择之后,控件显示的是显示值而非实际值. 对于下拉框显示队列,可以有多种方法,但是经过测试大多数方法不适用,检索效率太低, ...

  10. html5重力感应事件之DeviceMotionEvent

    前言 今天主要介绍一下html5重力感应事件之DeviceMotionEvent,之前我的一篇文章http://www.haorooms.com/post/jquery_jGestures, 介绍了第 ...