轻松上手,快乐学习!

JS 教程

JS 首页JS 教程JS 简介JS 如何使用JS 输出JS 语句JS 语法JS 注释JS 变量JS 运算符JS 算法JS 赋值JS 数据类型JS 函数JS 对象JS 事件JS 字符串JS 字符串方法JS 数值JS 数值方法JS 数组JS 数组方法JS 数组排序JS 数组迭代JS 日期JS 日期格式JS 日期获取方法JS 日期设置方法JS 数学运算JS 随机数JS 布尔运算符JS 比较运算符JS 条件语句JS Switch 语句JS For 循环JS While 循环JS BreakJS 类型转换JS 位运算符JS 正则表达式JS 错误处理JS 作用域JS HoistingJS 严格模式JS this 关键词JS Let 关键词JS Const 关键词JS 箭头函数JS 类JS 调试JS 样式指南JS 最佳实践JS 常见错误JS 性能优化JS 保留关键词JS 版本JS ES5JS ES6JS JSONJS FormsForms APIObject 对象定义Object 对象属性Object 对象方法Object DisplayObject 对象访问器Object 对象构造器Object 对象原型Object ECMAScript 5JS 函数定义JS 函数参数JS 函数调用JS Call 函数JS Apply 函数JS 函数闭包Class 类简介Class 类继承Class StaticJS 回调JS 异步JS PromisesJS Async/AwaitDOM 简介DOM 方法DOM 文档DOM 元素DOM HTMLDOM CSSDOM 动画DOM 事件DOM 事件监听DOM 导航DOM 节点DOM 集合DOM 节点列表JS WindowJS ScreenJS LocationJS HistoryJS NavigatorJS 弹出框JS TimingJS CookiesAJAX 简介AJAX XMLHttpAJAX 请求AJAX 响应AJAX XML 文件AJAX PHPAJAX ASPAJAX 数据库AJAX 应用程序AJAX 实例JSON 简介JSON 语法JSON vs XMLJSON 数据类型JSON 解析JSON 字符串化JSON 对象JSON 数组JSON PHPJSON HTMLJSON JSONPWeb API 简介Web History APIWeb Storage APIWeb Geolocation APIjQuery 选择器jQuery HTMLjQuery CSSjQuery DOMJS 实例JS HTML DOMJS HTML 输入JS HTML 对象JS HTML 事件JS BrowserJS 编辑器JS 练习JS 测验

JS 参考手册

JS 参考手册(类别排序)JS 参考手册(字母排序)


JavaScript 日期格式


JavaScript 日期输入

有四种 JavaScript 日期输入格式:

类型 例子
ISO 日期 "2018-02-19" (国际标准)
短日期 "02/19/2018" 或者 "2018/02/19"
长日期 "Feb 19 2018" 或者 "19 Feb 2019"
完整日期 "Monday February 25 2015"

ISO 格式遵守 JavaScript 中的严格标准。

其他格式不太明确,可能是浏览器特定的。


JavaScript 日期输出

无论输入格式如何,JavaScript 默认将输出全文本字符串格式:


JavaScript ISO 日期

ISO 8601 是表现日期和时间的国际标准。

ISO 8601 语法 (YYYY-MM-DD) 也是首选的 JavaScript 日期格式:

实例(完整日期)

var d = new Date("2015-03-25");
亲自试一试 »

计算的日期相对于您的时区。

根据您的时区,上面的结果将在 2 月 18 日至 2 月 19 日之间变化。


ISO 日期(年和月)

写日期也可以不规定具体某日 (YYYY-MM):

实例

var d = new Date("2015-03");
亲自试一试 »

时区会对结果在 2 月 28 日至 3 月 1 日之间产生变化。


ISO 日期(只有年)

写日期也可以不规定具体的月和日 (YYYY):

实例

var d = new Date("2015");
亲自试一试 »

时区会对结果在 2017 年 12 月 31 日至 2018 年 1 月 1 日之间产生变化。


ISO 日期(完整的日期加时、分和秒)

写日期也可以添加时、分和秒 (YYYY-MM-DDTHH:MM:SS):

实例

var d = new Date("2015-03-25T12:00:00Z");
亲自试一试 »

日期和时间通过大写字母 T 来分隔。

UTC 时间通过大写字母 Z 来定义。

如果您希望修改相对于 UTC 的时间,请删除 Z 并用 +HH:MM 或 -HH:MM 代替:

实例

var d = new Date("2015-03-25T12:00:00-06:30");
亲自试一试 »

UTC(Universal Time Coordinated)等同于 GMT(格林威治时间)。

注释:UTC,协调世界时,又称世界统一时间,世界标准时间,国际协调时间。

在日期-时间字符串中省略 T 或 Z,在不同浏览器中会产生不同结果。


时区

在设置日期时,如果不规定时区,则 JavaScript 会使用浏览器的时区。

当获取日期时,如果不规定时区,则结果会被转换为浏览器时区。

换句话说,假如日期/时间以 GMT(格林威治标准时间)创建,该日期/时间将被转换为 CST(中国标准时间),如果用户从中国进行浏览。


JavaScript 短日期

短日期通常使用 "MM/DD/YYYY" 这样的语法:

实例

var d = new Date("03/25/2015");
亲自试一试 »

警告 !

在某些浏览器中,不带前导零的月或其会产生错误:

var d = new Date("2015-3-25");

"YYYY / MM / DD" 的行为未定义。

有些浏览器会尝试猜测格式。有些会返回 NaN

var d = new Date("2015/03/25");

"DD-MM-YYYY" 的行为也是未定义的。

有些浏览器会尝试猜测格式。有些会返回 NaN

var d = new Date("25-03-2015");

JavaScript 长日期

长日期通常以 "MMM DD YYYY" 这样的语法来写:

实例

var d = new Date("Mar 25 2015");
亲自试一试 »

月和天能够以任意顺序出现:

实例

var d = new Date("25 Mar 2015");
亲自试一试 »

并且,月能够以全称 (January) 或缩写 (Jan) 来写:

实例

var d = new Date("January 25 2015");
亲自试一试 »

实例

var d = new Date("Jan 25 2015");
亲自试一试 »

逗号会被忽略,且对大小写不敏感:

实例

var d = new Date("JANUARY, 25, 2015");
亲自试一试 »

Date Input - 解析日期

如果是有效的日期字符串,可以使用 Date.parse() 方法将其转换为毫秒。

Date.parse() 返回日期和1970年1月1日之间的毫秒数:

实例

var msec = Date.parse("March 21, 2012");
document.getElementById("demo").innerHTML = msec;
亲自试一试 »

然后可以使用毫秒数将其转换为日期对象:

实例

var msec = Date.parse("March 21, 2012");
var d = new Date(msec);
document.getElementById("demo").innerHTML = d;
亲自试一试 »