如何格式化 JavaScript 日期
Posted
技术标签:
【中文标题】如何格式化 JavaScript 日期【英文标题】:How to format a JavaScript date 【发布时间】:2011-04-02 22:05:59 【问题描述】:在 javascript 中,如何格式化日期对象以打印为 10-Aug-2010
?
【问题讨论】:
像往常一样:当心这个月是零索引的!所以一月是零而不是一...... 另外请注意,myDate.getDay()
不会返回星期几,而是返回与星期相关的工作日位置。 myDate.getDate()
返回当前工作日。
你可以使用toLocaleDateString
@onmyway 你实际上不能。 developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/…
如果您正在寻找如何将字符串解析为 Date 对象,请参阅 Parsing a string to a date in JavaScript。
【参考方案1】:
如果您需要对格式的控制比当前接受的答案略少,Date#toLocaleDateString
可用于创建标准区域设置特定的渲染。 locale
和 options
参数让应用程序指定应该使用其格式约定的语言,并允许对呈现进行一些自定义。
选项键示例:
-
日期:
当天的代表。
可能的值为“数字”、“2 位”。
工作日:
工作日的表示。
可能的值为“narrow”、“short”、“long”。
年份:
年度的代表。
可能的值为“数字”、“2 位”。
月份:
月份的表示。
可能的值为“numeric”、“2-digit”、“narrow”、“short”、“long”。
小时:
小时的表示。
可能的值为“数字”、“2 位”。
分钟:
分钟的表示。
可能的值为“数字”、“2 位”。
第二:
第二个的代表。
可能的值为“数字”、2 位数字。
所有这些键都是可选的。您可以根据需要更改选项值的数量,这也将反映每个日期时间项的存在。
注意:如果您只想配置内容选项,但仍使用当前语言环境,则为第一个参数传递null
将导致错误。请改用undefined
。
对于不同的语言:
-
“en-US”:英文版
“hi-IN”: 用于印地语
“ja-JP”: 用于日语
您可以使用更多语言选项。
例如
var options = weekday: 'long', year: 'numeric', month: 'long', day: 'numeric' ;
var today = new Date();
console.log(today.toLocaleDateString("en-US")); // 9/17/2016
console.log(today.toLocaleDateString("en-US", options)); // Saturday, September 17, 2016
console.log(today.toLocaleDateString("hi-IN", options)); // शनिवार, 17 सितंबर 2016
您也可以将toLocaleString()
方法用于相同目的。唯一的区别是这个函数提供了你不传递任何选项的时间。
// Example
9/17/2016, 1:21:34 PM
参考资料:
toLocaleString()
toLocaleDateString()
【讨论】:
this 说它是非标准的,但mozzilla 没有指定 似乎这个答案应该是最好的“当前”答案。还使用选项“hour12: true”来使用 12 小时制与 24 小时制格式。也许应该在答案中添加到您的摘要列表中。 @Iarwa1n 此答案未提及,但您可以使用 toLocaleDateString 仅返回某些部分,然后您可以根据需要加入这些部分。在下面检查我的答案。date.toLocaleDateString("en-US", day: 'numeric' ) + "-"+ date.toLocaleDateString("en-US", month: 'short' ) + "-" + date.toLocaleDateString("en-US", year: 'numeric' )
应该给16-Nov-2019
对以下链接进行了长时间的挖掘,但我发现了它们的隐藏位置@MosesSchwartz:developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/…
@KVij——这是一种非常低效的日期格式化方式,尤其是考虑到有一个 formatToParts method 会返回对象数组中的所有部分。【参考方案2】:
对于自定义分隔的日期格式,您必须提取日期(或时间)
来自DateTimeFormat
对象的组件(它是
ECMAScript Internationalization API),然后手动创建字符串
用你想要的分隔符。
为此,您可以使用DateTimeFormat#formatToParts
。你可以
解构数组,但这并不理想,因为数组输出取决于
语言环境:
// example 1
let f = new Intl.DateTimeFormat('en');
let a = f.formatToParts();
console.log(a);
// example 2
let f = new Intl.DateTimeFormat('hi');
let a = f.formatToParts();
console.log(a);
最好将格式数组映射到结果字符串:
function join(t, a, s)
function format(m)
let f = new Intl.DateTimeFormat('en', m);
return f.format(t);
return a.map(format).join(s);
let a = [day: 'numeric', month: 'short', year: 'numeric'];
let s = join(new Date, a, '-');
console.log(s);
您也可以使用以下方法一一拉出DateTimeFormat
的各个部分
DateTimeFormat#format
,但是注意使用这个方法的时候,截至3月
2020 年,ECMAScript 实现中有a bug
分钟和秒的前导零(这个错误被方法规避了
以上)。
let d = new Date(2010, 7, 5);
let ye = new Intl.DateTimeFormat('en', year: 'numeric' ).format(d);
let mo = new Intl.DateTimeFormat('en', month: 'short' ).format(d);
let da = new Intl.DateTimeFormat('en', day: '2-digit' ).format(d);
console.log(`$da-$mo-$ye`);
在处理日期和时间时,通常值得使用库(例如。 moment.js, luxon) 因为许多隐藏的复杂性 字段。
请注意,上述解决方案中使用的 ECMAScript 国际化 API 不支持in IE10(0.03%2月全球浏览器市场份额 2020)。
【讨论】:
或者扩展Date
对象,就像我在***.com/questions/3187790/…做的那样
我知道ye
是年,mo
是月,da
是日。 o
是什么? a
是什么? m
是什么?你能用正确的变量名吗?
2021 年,momentjs 文档说我们希望阻止 Moment 被用于未来的新项目【参考方案3】:
使用date.format library:
var dateFormat = require('dateformat');
var now = new Date();
dateFormat(now, "dddd, mmmm dS, yyyy, h:MM:ss TT");
返回:
Saturday, June 9th, 2007, 5:46:21 PM
dateformat on npm
http://jsfiddle.net/phZr7/1/
【讨论】:
他的“L”代码是错误的,他应该删除“L > 99?”部分......除此之外,它非常整洁,即使不是太好本地化。 此解决方案也可作为 npm 包提供:npmjs.com/package/dateformat 如果你要麻烦导入一个外部依赖,我推荐使用moment.js。它可以进行这种类型的日期格式化:momentjs.com/docs/#/displaying 它还有更多的功能。 与 IE 中的 Date API 相比,timezone 也适用于日期格式【参考方案4】:如果您需要使用纯 JavaScript 快速格式化日期,请使用 getDate
、getMonth + 1
、getFullYear
、getHours
和 getMinutes
:
var d = new Date();
var datestring = d.getDate() + "-" + (d.getMonth()+1) + "-" + d.getFullYear() + " " +
d.getHours() + ":" + d.getMinutes();
// 16-5-2015 9:50
或者,如果您需要用零填充它:
var datestring = ("0" + d.getDate()).slice(-2) + "-" + ("0"+(d.getMonth()+1)).slice(-2) + "-" +
d.getFullYear() + " " + ("0" + d.getHours()).slice(-2) + ":" + ("0" + d.getMinutes()).slice(-2);
// 16-05-2015 09:50
【讨论】:
你也可以用.toString().padStart(2, '0')
补零
@BennyJobigan 应该提到的是,String.padStart()
仅适用于 ECMAScript 2017。【参考方案5】:
好吧,我想要将今天的日期转换为 mysql 友好的日期字符串,例如 2012-06-23
,并在我的一个查询中使用该字符串作为参数。我找到的简单解决方案是这样的:
var today = new Date().toISOString().slice(0, 10);
请记住,上述解决方案没有考虑您的时区偏移量。
您可以考虑改用这个函数:
function toJSONLocal (date)
var local = new Date(date);
local.setMinutes(date.getMinutes() - date.getTimezoneOffset());
return local.toJSON().slice(0, 10);
如果您在一天的开始/结束时执行此代码,这将为您提供正确的日期。
var date = new Date();
function toLocal(date)
var local = new Date(date);
local.setMinutes(date.getMinutes() - date.getTimezoneOffset());
return local.toJSON();
function toJSONLocal(date)
var local = new Date(date);
local.setMinutes(date.getMinutes() - date.getTimezoneOffset());
return local.toJSON().slice(0, 10);
// check out your devtools console
console.log(date.toJSON());
console.log(date.toISOString());
console.log(toLocal(date));
console.log(toJSONLocal(date));
Date.toISOString
Date.toJSON
String.slice
External example
【讨论】:
您可以使用new Date(date + " UTC")
来欺骗时区,并且可以消除 setMinutes 行。伙计,javascript 很脏
Y10K 兼容版本:var today = new Date().toISOString().slice(0,-14)
:)
或者这样new Date().toISOString().split('T')[0]
new Date().toISOString().slice(0, 16).replace('T',' ')
包括时间
只是评论说缺少时区并不是“一天开始/结束时”的一些小不便。例如,在澳大利亚,直到上午 11 点左右,日期可能是错误的——将近半天!【参考方案6】:
自定义格式化功能:
对于固定格式,只需一个简单的函数即可完成工作。以下示例生成国际格式 YYYY-MM-DD:
function dateToYMD(date)
var d = date.getDate();
var m = date.getMonth() + 1; //Month from 0 to 11
var y = date.getFullYear();
return '' + y + '-' + (m<=9 ? '0' + m : m) + '-' + (d <= 9 ? '0' + d : d);
console.log(dateToYMD(new Date(2017,10,5))); // Nov 5
OP 格式可能生成如下:
function dateToYMD(date)
var strArray=['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec'];
var d = date.getDate();
var m = strArray[date.getMonth()];
var y = date.getFullYear();
return '' + (d <= 9 ? '0' + d : d) + '-' + m + '-' + y;
console.log(dateToYMD(new Date(2017,10,5))); // Nov 5
注意:但是,扩展 JavaScript 标准库通常不是一个好主意(例如,通过将此函数添加到 Date 的原型中)。
更高级的功能可以根据格式参数生成可配置的输出。
如果编写格式化函数太长,有很多库可以做到这一点。其他一些答案已经列举了它们。但增加的依赖也有它的对应部分。
标准 ECMAScript 格式化函数:
由于 ECMAScript 的更新版本,Date
类具有一些特定的格式化功能:
toDateString:依赖于实现,只显示日期。
https://262.ecma-international.org/#sec-date.prototype.todatestring
new Date().toDateString(); // e.g. "Fri Nov 11 2016"
toISOString:显示 ISO 8601 日期和时间。
https://262.ecma-international.org/#sec-date.prototype.toisostring
new Date().toISOString(); // e.g. "2016-11-21T08:00:00.000Z"
toJSON:JSON 的字符串化符。
https://262.ecma-international.org/#sec-date.prototype.tojson
new Date().toJSON(); // e.g. "2016-11-21T08:00:00.000Z"
toLocaleDateString:依赖于实现,区域格式的日期。
https://262.ecma-international.org/#sec-date.prototype.tolocaledatestring
new Date().toLocaleDateString(); // e.g. "21/11/2016"
toLocaleString:依赖于实现,采用语言环境格式的日期和时间。
https://262.ecma-international.org/#sec-date.prototype.tolocalestring
new Date().toLocaleString(); // e.g. "21/11/2016, 08:00:00 AM"
toLocaleTimeString:依赖于实现,区域格式的时间。
https://262.ecma-international.org/#sec-date.prototype.tolocaletimestring
new Date().toLocaleTimeString(); // e.g. "08:00:00 AM"
toString:日期的通用 toString。
https://262.ecma-international.org/#sec-date.prototype.tostring
new Date().toString(); // e.g. "Fri Nov 21 2016 08:00:00 GMT+0100 (W. Europe Standard Time)"
注意:可以从这些格式中生成自定义输出 >
new Date().toISOString().slice(0,10); //return YYYY-MM-DD
示例 sn-ps:
console.log("1) "+ new Date().toDateString());
console.log("2) "+ new Date().toISOString());
console.log("3) "+ new Date().toJSON());
console.log("4) "+ new Date().toLocaleDateString());
console.log("5) "+ new Date().toLocaleString());
console.log("6) "+ new Date().toLocaleTimeString());
console.log("7) "+ new Date().toString());
console.log("8) "+ new Date().toISOString().slice(0,10));
为标准函数指定语言环境:
上面列出的一些标准函数取决于语言环境:
toLocaleDateString()
toLocaleTimeString()
toLocalString()
这是因为不同的文化使用不同的格式,并以不同的方式表达他们的日期或时间。 默认情况下,该函数将返回在其运行的设备上配置的格式,但这可以通过设置参数 (ECMA-402) 来指定。
toLocaleDateString([locales[, options]])
toLocaleTimeString([locales[, options]])
toLocaleString([locales[, options]])
//e.g. toLocaleDateString('ko-KR');
option
第二个参数,允许在所选语言环境中配置更具体的格式。例如,月份可以显示为全文或缩写。
toLocaleString('en-GB', month: 'short' )
toLocaleString('en-GB', month: 'long' )
示例 sn-ps:
console.log("1) "+ new Date().toLocaleString('en-US'));
console.log("2) "+ new Date().toLocaleString('ko-KR'));
console.log("3) "+ new Date().toLocaleString('de-CH'));
console.log("4) "+ new Date().toLocaleString('en-GB', hour12: false ));
console.log("5) "+ new Date().toLocaleString('en-GB', hour12: true ));
关于语言环境的一些良好做法:
大多数人不喜欢他们的日期以外国人格式显示,因此,尽可能保留默认区域设置(而不是到处设置“en-US”)。 实现从/到 UTC 的转换可能具有挑战性(考虑到 DST、时区不是 1 小时的倍数等)。尽可能使用经过良好测试的库。 不要假设区域设置与一个国家/地区相关:几个国家/地区有很多(加拿大、印度等) 避免通过非标准方式检测语言环境。在这里您可以了解多个陷阱:检测键盘布局、通过地理位置检测语言环境等。【讨论】:
我认为英国示例的语言环境应该是“en-GB”以获得“dd/mm/yyyy”格式 我解决了这个问题。谢谢 很好地列出了Intl.DateTimeFormat() constructor
支持的参数在这里列出:developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/…
感谢您从不使用“ECMA vodoo”的示例开始
.toJSON()
在后台使用.toIsoString()
(根据docs)。 需要注意 ISO 转换会转换为另一个时区,这可能会更改日期部分(请参阅其他 cmets)。此外,似乎 OP 想要转换为 Oracle(等)“语言环境/文化”,而不是人类......【参考方案7】:
如果您在项目中已经在使用 jQuery UI,您可以这样做:
var formatted = $.datepicker.formatDate("M d, yy", new Date("2014-07-08T09:02:21.377"));
// formatted will be 'Jul 8, 2014'
here 提供了一些日期选择器日期格式选项。
【讨论】:
【参考方案8】:我认为你可以只使用非标准日期方法toLocaleFormat(formatString)
formatString:格式字符串与 C 中的 strftime()
函数所期望的格式相同。
var today = new Date();
today.toLocaleFormat('%d-%b-%Y'); // 30-Dec-2011
参考资料:
tolocaleformat strftime【讨论】:
toLocaleFormat() 似乎只适用于 Firefox。 IE 和 Chrome 对我来说都失败了。 Chrome 有 .toLocaleString('en') 方法。似乎新的浏览器支持这个developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/… 在此处阅读警告:developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/…new Intl.DateTimeFormat
似乎是替换 developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/…
7 年后,该功能在其他浏览器中仍然无法使用,并在 Firefox 中被弃用 Deprecated_toLocaleFormat【参考方案9】:
纯 JavaScript 是小型一次性用户的最佳选择。
另一方面,如果您需要更多日期信息,MomentJS 是一个很好的解决方案。
例如:
moment().format('YYYY-MM-DD HH:m:s'); // now() -> 2015-03-24 14:32:20
moment("20111031", "YYYYMMDD").fromNow(); // 3 years ago
moment("20120620", "YYYYMMDD").fromNow(); // 3 years ago
moment().startOf('day').fromNow(); // 11 hours ago
moment().endOf('day').fromNow(); // in 13 hours
【讨论】:
重要的是:不要使用YYYY
,除非你知道YYYY
和yyyy
之间的区别:***.com/questions/15133549/…
@Domin 特定于 ios 中的 NSDateFormatter,例如从Objective-C 或 Swift。这个问题是关于浏览器中的 Javascript,这个答案使用 MomentJS,其中YYYY
(不是yyyy
)是标准年份,GGGG
(不是YYYY
)是基于 ISO 周的年份。跨度>
【参考方案10】:
在现代浏览器 (*) 中,您可以这样做:
var today = new Date().toLocaleDateString('en-GB',
day : 'numeric',
month : 'short',
year : 'numeric'
).split(' ').join('-');
今天执行的输出(2016 年 1 月 24 日):
'24-Jan-2016'
(*) According to MDN,“现代浏览器”是指 Chrome 24+、Firefox 29+、Internet Explorer 11、Edge 12+、Opera 15+ 和 Safari nightly build。
【讨论】:
【参考方案11】:在一行中请求格式 - 没有库也没有 Date 方法,只有正则表达式:
var d = (new Date()).toString().replace(/\S+\s(\S+)\s(\d+)\s(\d+)\s.*/,'$2-$1-$3');
// date will be formatted as "14-Oct-2015" (pass any date object in place of 'new Date()')
在我的测试中,这在主要浏览器(Chrome、Safari、Firefox 和 IE)中都能可靠运行。正如@RobG 所指出的,Date.prototype.toString() 的输出取决于实现,因此对于国际或非- 浏览器实现,只需测试输出以确保它在您的 JavaScript 引擎中正常工作。您甚至可以添加一些代码来测试字符串输出,并在进行正则表达式替换之前确保它与您期望的匹配。
【讨论】:
【参考方案12】:@Sébastien -- 替代所有浏览器支持
new Date(parseInt(496407600)*1000).toLocaleDateString('de-DE',
year: 'numeric',
month: '2-digit',
day: '2-digit'
).replace(/\./g, '/');
文档: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/toLocaleDateString
基于 Date.toLocaleDateString 的高阶标记模板文字示例:
const date = new Date(Date.UTC(2020, 4, 2, 3, 23, 16, 738));
const fmt = (dt, lc = "en-US") => (str, ...expr) =>
str.map((str, i) => str + (expr[i]?dt.toLocaleDateString(lc, expr[i]) :'')).join('')
console.log(fmt(date)`$year: 'numeric'-$month: '2-digit'-$day: '2-digit'`);
// expected output: "2020-05-02"
【讨论】:
您可以简单地使用 'en-GB' 作为语言环境,而不是使用 .replace()。 :)【参考方案13】:打包解决方案: Luxon
如果您想使用一个适合所有人的解决方案,我强烈建议您使用 Luxon(Moment.js 的现代化版本),它还可以在许多区域设置/语言和大量其他功能中进行格式化。
Luxon 托管在 Moment.js 网站上,由 Moment.js 开发人员开发,因为 Moment.js 存在开发人员想要解决但无法解决的限制。
安装:
npm install luxon
或yarn add luxon
(其他安装方式请访问链接)
例子:
luxon.DateTime.fromISO('2010-08-10').toFormat('yyyy-LLL-dd');
产量:
2010 年 8 月 10 日
手动解决方案
使用与 Moment.js、Class DateTimeFormatter (Java) 和 Class SimpleDateFormat (Java) 类似的格式,我实现了一个全面的解决方案 formatDate(date, patternStr)
,其中代码易于阅读和修改。您可以显示日期、时间、上午/下午等。更多示例请参见代码。
例子:
formatDate(new Date(), 'EEEE, MMMM d, yyyy HH:mm:ss:S')
(formatDate
在下面的代码sn-p中实现)
产量:
2018 年 10 月 12 日星期五 18:11:23:445
点击“运行代码 sn-p”来试用代码。
日期和时间模式
yy
= 2 位数年份; yyyy
= 全年
M
= 数字月份; MM
= 2 位数的月份; MMM
= 短月份名称; MMMM
= 完整月份名称
EEEE
= 完整的工作日名称; EEE
= 简短的工作日名称
d
= 数字日; dd
= 2 位数的日期
h
= 上午/下午小时; hh
= 上午/下午两位数小时; H
= 小时; HH
= 2 位数的小时数
m
= 分钟; mm
= 2 位数分钟; aaa
= 上午/下午
s
= 秒; ss
= 2 位秒数
S
= 毫秒
var monthNames = [
"January", "February", "March", "April", "May", "June", "July",
"August", "September", "October", "November", "December"
];
var dayOfWeekNames = [
"Sunday", "Monday", "Tuesday",
"Wednesday", "Thursday", "Friday", "Saturday"
];
function formatDate(date, patternStr)
if (!patternStr)
patternStr = 'M/d/yyyy';
var day = date.getDate(),
month = date.getMonth(),
year = date.getFullYear(),
hour = date.getHours(),
minute = date.getMinutes(),
second = date.getSeconds(),
miliseconds = date.getMilliseconds(),
h = hour % 12,
hh = twoDigitPad(h),
HH = twoDigitPad(hour),
mm = twoDigitPad(minute),
ss = twoDigitPad(second),
aaa = hour < 12 ? 'AM' : 'PM',
EEEE = dayOfWeekNames[date.getDay()],
EEE = EEEE.substr(0, 3),
dd = twoDigitPad(day),
M = month + 1,
MM = twoDigitPad(M),
MMMM = monthNames[month],
MMM = MMMM.substr(0, 3),
yyyy = year + "",
yy = yyyy.substr(2, 2)
;
// checks to see if month name will be used
patternStr = patternStr
.replace('hh', hh).replace('h', h)
.replace('HH', HH).replace('H', hour)
.replace('mm', mm).replace('m', minute)
.replace('ss', ss).replace('s', second)
.replace('S', miliseconds)
.replace('dd', dd).replace('d', day)
.replace('EEEE', EEEE).replace('EEE', EEE)
.replace('yyyy', yyyy)
.replace('yy', yy)
.replace('aaa', aaa);
if (patternStr.indexOf('MMM') > -1)
patternStr = patternStr
.replace('MMMM', MMMM)
.replace('MMM', MMM);
else
patternStr = patternStr
.replace('MM', MM)
.replace('M', M);
return patternStr;
function twoDigitPad(num)
return num < 10 ? "0" + num : num;
console.log(formatDate(new Date()));
console.log(formatDate(new Date(), 'dd-MMM-yyyy')); //OP's request
console.log(formatDate(new Date(), 'EEEE, MMMM d, yyyy HH:mm:ss.S aaa'));
console.log(formatDate(new Date(), 'EEE, MMM d, yyyy HH:mm'));
console.log(formatDate(new Date(), 'yyyy-MM-dd HH:mm:ss.S'));
console.log(formatDate(new Date(), 'M/dd/yyyy h:mmaaa'));
感谢 @Gerry 提出 Luxon。
【讨论】:
【参考方案14】:好的,我们有一个叫做 Intl 的东西,这对于在 JavaScript 中格式化日期非常有用:
您的日期如下:
var date = '10/8/2010';
然后您使用 new Date() 更改为 Date,如下所示:
date = new Date(date);
现在您可以使用 locales 列表以任何您喜欢的方式对其进行格式化,如下所示:
date = new Intl.DateTimeFormat('en-AU').format(date); // Australian date format: "8/10/2010"
date = new Intl.DateTimeFormat('en-US').format(date); // USA date format: "10/8/2010"
date = new Intl.DateTimeFormat('ar-EG').format(date); // Arabic date format: "٨/١٠/٢٠١٠"
如果你确实想要上面提到的格式,你可以这样做:
date = new Date(Date.UTC(2010, 7, 10, 0, 0, 0));
var options = year: "numeric", month: "short", day: "numeric";
date = new Intl.DateTimeFormat("en-AU", options).format(date).replace(/\s/g, '-');
结果将是:
"10-Aug-2010"
有关更多信息,请参阅 Intl API 和 Intl.DateTimeFormat 文档。
【讨论】:
IE不支持 它只是 IE11,IE10- 在这之前已经过时了,所以这是可以理解的。 92% 来自 caniuse,相当不错caniuse.com/#search=datetimeformat【参考方案15】:使用 ECMAScript Edition 6 (ES6/ES2015) 字符串模板:
let d = new Date();
let formatted = `$d.getFullYear()-$d.getMonth() + 1-$d.getDate()`;
如果需要更改分隔符:
const delimiter = '/';
let formatted = [d.getFullYear(), d.getMonth() + 1, d.getDate()].join(delimiter);
【讨论】:
【参考方案16】:Date
构造函数(和Date.parse()
)在构造日期时只接受一种格式作为参数,即ISO 8601:
// new Date('YYYY-MM-DDTHH:mm:ss.sssZ')
const date = new Date('2017-08-15')
但是由于浏览器的差异和不一致,强烈建议不要从字符串中解析 a(MDN 建议不要使用日期字符串创建日期)。
推荐的替代方法是直接从数字数据构建您的 Date 实例,如下所示:
new Date(2017, 7, 15) // Month is zero-indexed
那是解析。现在,要将您的日期格式化为您想要的字符串,您有几个选项是 Date 对象的原生选项(尽管我相信没有一个符合您需要的格式):
date.toString() // 'Wed Jan 23 2019 17:23:42 GMT+0800 (Singapore Standard Time)'
date.toDateString() // 'Wed Jan 23 2019'
date.toLocaleString() // '23/01/2019, 17:23:42'
date.toGMTString() // 'Wed, 23 Jan 2019 09:23:42 GMT'
date.toUTCString() // 'Wed, 23 Jan 2019 09:23:42 GMT'
date.toISOString() // '2019-01-23T09:23:42.079Z'
对于其他格式选项,恐怕您必须求助于 Moment.js、day.js 等库。
感谢 Zell Liew from this article 获取日期格式提示。
【讨论】:
【参考方案17】:不使用任何外部库的 JavaScript 解决方案:
var now = new Date()
months = ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
var formattedDate = now.getDate() + "-" + months[now.getMonth()] + "-" + now.getFullYear()
alert(formattedDate)
【讨论】:
【参考方案18】:这是我刚刚编写的一些代码,用于处理我正在处理的项目的日期格式。它模仿 php 日期格式化功能来满足我的需要。随意使用它,它只是扩展已经存在的 Date() 对象。这可能不是最优雅的解决方案,但它可以满足我的需求。
var d = new Date();
d_string = d.format("m/d/Y h:i:s");
/**************************************
* Date class extension
*
*/
// Provide month names
Date.prototype.getMonthName = function()
var month_names = [
'January',
'February',
'March',
'April',
'May',
'June',
'July',
'August',
'September',
'October',
'November',
'December'
];
return month_names[this.getMonth()];
// Provide month abbreviation
Date.prototype.getMonthAbbr = function()
var month_abbrs = [
'Jan',
'Feb',
'Mar',
'Apr',
'May',
'Jun',
'Jul',
'Aug',
'Sep',
'Oct',
'Nov',
'Dec'
];
return month_abbrs[this.getMonth()];
// Provide full day of week name
Date.prototype.getDayFull = function()
var days_full = [
'Sunday',
'Monday',
'Tuesday',
'Wednesday',
'Thursday',
'Friday',
'Saturday'
];
return days_full[this.getDay()];
;
// Provide full day of week name
Date.prototype.getDayAbbr = function()
var days_abbr = [
'Sun',
'Mon',
'Tue',
'Wed',
'Thur',
'Fri',
'Sat'
];
return days_abbr[this.getDay()];
;
// Provide the day of year 1-365
Date.prototype.getDayOfYear = function()
var onejan = new Date(this.getFullYear(),0,1);
return Math.ceil((this - onejan) / 86400000);
;
// Provide the day suffix (st,nd,rd,th)
Date.prototype.getDaySuffix = function()
var d = this.getDate();
var sfx = ["th","st","nd","rd"];
var val = d%100;
return (sfx[(val-20)%10] || sfx[val] || sfx[0]);
;
// Provide Week of Year
Date.prototype.getWeekOfYear = function()
var onejan = new Date(this.getFullYear(),0,1);
return Math.ceil((((this - onejan) / 86400000) + onejan.getDay()+1)/7);
// Provide if it is a leap year or not
Date.prototype.isLeapYear = function()
var yr = this.getFullYear();
if ((parseInt(yr)%4) == 0)
if (parseInt(yr)%100 == 0)
if (parseInt(yr)%400 != 0)
return false;
if (parseInt(yr)%400 == 0)
return true;
if (parseInt(yr)%100 != 0)
return true;
if ((parseInt(yr)%4) != 0)
return false;
;
// Provide Number of Days in a given month
Date.prototype.getMonthDayCount = function()
var month_day_counts = [
31,
this.isLeapYear() ? 29 : 28,
31,
30,
31,
30,
31,
31,
30,
31,
30,
31
];
return month_day_counts[this.getMonth()];
// format provided date into this.format format
Date.prototype.format = function(dateFormat)
// break apart format string into array of characters
dateFormat = dateFormat.split("");
var date = this.getDate(),
month = this.getMonth(),
hours = this.getHours(),
minutes = this.getMinutes(),
seconds = this.getSeconds();
// get all date properties ( based on PHP date object functionality )
var date_props =
d: date < 10 ? '0'+date : date,
D: this.getDayAbbr(),
j: this.getDate(),
l: this.getDayFull(),
S: this.getDaySuffix(),
w: this.getDay(),
z: this.getDayOfYear(),
W: this.getWeekOfYear(),
F: this.getMonthName(),
m: month < 10 ? '0'+(month+1) : month+1,
M: this.getMonthAbbr(),
n: month+1,
t: this.getMonthDayCount(),
L: this.isLeapYear() ? '1' : '0',
Y: this.getFullYear(),
y: this.getFullYear()+''.substring(2,4),
a: hours > 12 ? 'pm' : 'am',
A: hours > 12 ? 'PM' : 'AM',
g: hours % 12 > 0 ? hours % 12 : 12,
G: hours > 0 ? hours : "12",
h: hours % 12 > 0 ? hours % 12 : 12,
H: hours,
i: minutes < 10 ? '0' + minutes : minutes,
s: seconds < 10 ? '0' + seconds : seconds
;
// loop through format array of characters and add matching data else add the format character (:,/, etc.)
var date_string = "";
for(var i=0;i<dateFormat.length;i++)
var f = dateFormat[i];
if(f.match(/[a-zA-Z]/g))
date_string += date_props[f] ? date_props[f] : '';
else
date_string += f;
return date_string;
;
/*
*
* END - Date class extension
*
************************************/
【讨论】:
【参考方案19】:在 JavaScript 中格式化 DateTimes 的一种有用且灵活的方法是 Intl.DateTimeFormat
:
var date = new Date();
var options = year: 'numeric', month: 'short', day: '2-digit';
var _resultDate = new Intl.DateTimeFormat('en-GB', options).format(date);
// The _resultDate is: "12 Oct 2017"
// Replace all spaces with - and then log it.
console.log(_resultDate.replace(/ /g,'-'));
结果是:"12-Oct-2017"
可以使用 options 参数自定义日期和时间格式。
Intl.DateTimeFormat
对象是启用语言敏感日期和时间格式的对象的构造函数。
语法
new Intl.DateTimeFormat([locales[, options]])
Intl.DateTimeFormat.call(this[, locales[, options]])
参数
地区
可选。带有 BCP 47 语言标记的字符串,或此类字符串的数组。有关 locales 参数的一般形式和解释,请参阅 Intl 页面。允许使用以下 Unicode 扩展键:
nu
Numbering system. Possible values include: "arab", "arabext", "bali", "beng", "deva", "fullwide", "gujr", "guru", "hanidec", "khmr", "knda", "laoo", "latn", "limb", "mlym", "mong", "mymr", "orya", "tamldec", "telu", "thai", "tibt".
ca
Calendar. Possible values include: "buddhist", "chinese", "coptic", "ethioaa", "ethiopic", "gregory", "hebrew", "indian", "islamic", "islamicc", "iso8601", "japanese", "persian", "roc".
选项
可选。具有以下部分或全部属性的对象:
localeMatcher
要使用的语言环境匹配算法。可能的值为"lookup"
和"best fit"
;默认为"best fit"
。有关此选项的信息,请参阅 Intl 页面。
时区
要使用的时区。实现必须识别的唯一值是"UTC"
;默认值是运行时的默认时区。实现还可以识别 IANA 时区数据库的时区名称,例如 "Asia/Shanghai"
、"Asia/Kolkata"
、"America/New_York"
。
12 小时
是否使用 12 小时制(而不是 24 小时制)。可能的值为true
和false
;默认值取决于区域设置。
格式匹配器
要使用的格式匹配算法。可能的值为"basic"
和"best fit"
;默认为"best fit"
。有关使用此属性的信息,请参阅以下段落。
以下属性描述了在格式化输出中使用的日期时间组件及其所需的表示形式。实现需要至少支持以下子集:
weekday, year, month, day, hour, minute, second
weekday, year, month, day
year, month, day
year, month
month, day
hour, minute, second
hour, minute
实现可能支持其他子集,并且将针对所有可用的子集表示组合协商请求以找到最佳匹配。两种算法可用于此协商并由 formatMatcher 属性选择:完全指定的"basic"
算法和依赖于实现的“最佳拟合”算法。
工作日
工作日的表示。可能的值为"narrow"
、"short"
、"long"
。
时代
时代的代表。可能的值为"narrow"
、"short"
、"long"
。
年份
年份的表示。可能的值为"numeric"
、"2-digit"
。
月
月份的表示。可能的值为"numeric"
、"2-digit"
、"narrow"
、"short"
、"long"
。
一天
当天的表现。可能的值为"numeric"
、"2-digit"
。
小时
小时的表示。可能的值为"numeric"
、"2-digit"
。
分钟
分钟的表示。可能的值为"numeric"
、"2-digit"
。
秒
第二个的表示。可能的值为"numeric"
、"2-digit"
。
时区名称
时区名称的表示。可能的值为"short"
、"long"
。
每个日期时间组件属性的默认值未定义,但如果所有组件属性未定义,则假定年月日为"numeric"
。
Check Online
More Details
【讨论】:
【参考方案20】:new Date().toLocaleDateString()
// "3/21/2018"
更多文档请访问developer.mozilla.org
【讨论】:
【参考方案21】:我们有很多解决方案,但我认为其中最好的是 Moment.js。所以我个人建议使用 Moment.js 进行日期和时间的操作。
console.log(moment().format('DD-MMM-YYYY'));
<script src="//cdnjs.cloudflare.com/ajax/libs/moment.js/2.14.1/moment.min.js"></script>
【讨论】:
【参考方案22】:这可能有助于解决问题:
var d = new Date();
var options =
day: 'numeric',
month: 'long',
year: 'numeric'
;
console.log(d.toLocaleDateString('en-ZA', options));
【讨论】:
【参考方案23】:如果您在代码中使用 jQuery UI,则有一个名为 formatDate()
的内置函数。我用这种方式来格式化今天的日期:
var testdate = Date();
testdate = $.datepicker.formatDate( "d-M-yy",new Date(testdate));
alert(testdate);
你可以看到many other examples of formatting date in the jQuery UI documentation。
【讨论】:
【参考方案24】:这就是我为我的 npm 插件实现的方式
var monthNames = [
"January", "February", "March",
"April", "May", "June", "July",
"August", "September", "October",
"November", "December"
];
var Days = [
"Sunday", "Monday", "Tuesday", "Wednesday",
"Thursday", "Friday", "Saturday"
];
var formatDate = function(dt,format)
format = format.replace('ss', pad(dt.getSeconds(),2));
format = format.replace('s', dt.getSeconds());
format = format.replace('dd', pad(dt.getDate(),2));
format = format.replace('d', dt.getDate());
format = format.replace('mm', pad(dt.getMinutes(),2));
format = format.replace('m', dt.getMinutes());
format = format.replace('MMMM', monthNames[dt.getMonth()]);
format = format.replace('MMM', monthNames[dt.getMonth()].substring(0,3));
format = format.replace('MM', pad(dt.getMonth()+1,2));
format = format.replace(/M(?![ao])/, dt.getMonth()+1);
format = format.replace('DD', Days[dt.getDay()]);
format = format.replace(/D(?!e)/, Days[dt.getDay()].substring(0,3));
format = format.replace('yyyy', dt.getFullYear());
format = format.replace('YYYY', dt.getFullYear());
format = format.replace('yy', (dt.getFullYear()+"").substring(2));
format = format.replace('YY', (dt.getFullYear()+"").substring(2));
format = format.replace('HH', pad(dt.getHours(),2));
format = format.replace('H', dt.getHours());
return format;
pad = function(n, width, z)
z = z || '0';
n = n + '';
return n.length >= width ? n : new Array(width - n.length + 1).join(z) + n;
【讨论】:
你指的是哪个包? 这里有个bug:先替换月份名,然后再替换月份名。例如,March
将使用此代码变为 3arch
。
将'M'
的行更改为format = format.replace("M(?!M)", (dt.getMonth()+1).toString());
并将其放在'MMMM'
行的上方
这个例子的演示可以在这里找到:jsfiddle.net/Abeeee/Ly8v3s0x/24【参考方案25】:
你应该看看DayJs 这是对momentJs 的翻版,但面向模块化架构的架构如此轻巧。
具有相同现代 API 的 Moment.js 的快速 2kB 替代方案
Day.js 是一个极简的 JavaScript 库,它可以解析、验证、操作和显示现代浏览器的日期和时间,并具有很大程度上与 Moment.js 兼容的 API。如果你使用 Moment.js,你已经知道如何使用 Day.js。
var date = Date.now();
const formatedDate = dayjs(date).format("YYYY-MM-DD")
console.log(formatedDate);
<script src="https://cdnjs.cloudflare.com/ajax/libs/dayjs/1.8.16/dayjs.min.js" crossorigin="anonymous"></script>
【讨论】:
【参考方案26】:var today = new Date();
var formattedToday = today.toLocaleDateString() + ' ' + today.toLocaleTimeString();
【讨论】:
【参考方案27】:截至 2019 年,您似乎可以让 toLocaleDateString 仅返回某些部分,然后您可以根据需要加入它们:
var date = new Date();
console.log(date.toLocaleDateString("en-US", day: 'numeric' )
+ "-"+ date.toLocaleDateString("en-US", month: 'short' )
+ "-" + date.toLocaleDateString("en-US", year: 'numeric' ) );
> 16-Nov-2019
console.log(date.toLocaleDateString("en-US", month: 'long' )
+ " " + date.toLocaleDateString("en-US", day: 'numeric' )
+ ", " + date.toLocaleDateString("en-US", year: 'numeric' ) );
> November 16, 2019
【讨论】:
【参考方案28】:受到JD Smith奇妙的正则表达式解决方案的启发,我突然有了一个让人头晕目眩的想法:
var D = Date().toString().split(" ");
console.log(D[2] + "-" + D[1] + "-" + D[3]);
【讨论】:
如果你在 DOM 中就需要它,那就太好了!【参考方案29】:对于任何寻求真正简单的 ES6 解决方案来复制、粘贴和采用的人:
const dateToString = d => `$d.getFullYear()-$('00' + (d.getMonth() + 1)).slice(-2)-$('00' + d.getDate()).slice(-2)`
// how to use:
const myDate = new Date(Date.parse('04 Dec 1995 00:12:00 GMT'))
console.log(dateToString(myDate)) // 1995-12-04
【讨论】:
小改进:为了确保两位数的结果,这工作正常:('0' + oneOrTwoDigitNumber).slice(-2)
。无需使用('00' + oneOrTwoDigitNumber).slice(-2)
,因为我们知道 oneOrTwoDigitNumber 的长度至少为一位。【参考方案30】:
为了将日期格式化为例如10-Aug-2010
,您可能想要使用 .toDateString()
和 ES6 数组解构。
const formattedDate = new Date().toDateString()
// The above yields e.g. 'Mon Jan 06 2020'
const [, month, day, year] = formattedDate.split(' ')
const ddMmmYyyy = `$day-$month-$year`
// or
const ddMmmYyyy = [day, month, year].join('-')
【讨论】:
以上是关于如何格式化 JavaScript 日期的主要内容,如果未能解决你的问题,请参考以下文章
如何将 JavaScript 日期转换为 MySQL 日期时间格式? [复制]
如何格式化要由 jQuery 序列化的 javascript 日期
如何在 JavaScript 中使用 ISO 8601 格式化带有时区偏移的日期?