有没有办法根据区域设置为长日期添加自定义格式代码?
例如:
moment().format("L")
是一种现有格式,可以打印语言环境的长日期(包括年份),但是如果我想添加我自己的那样排除年份:
moment().format("LTY")
只是在给定的区域设置中打印了月份和日期。
我该怎么做?
答案 0 :(得分:5)
阅读long date formats部分。您可以使用以下方法替换默认的长日期格式对象:
moment.updateLocale('en', {
longDateFormat : {
LT: "h:mm A",
LTS: "h:mm:ss A",
L: "MM/DD", // Remove year
LL: "MMMM Do YYYY",
LLL: "MMMM Do YYYY LT",
LLLL: "dddd, MMMM Do YYYY LT"
}
});
然后使用:
var x = moment().format('L');
Moment解析传递给 format 的字符串,寻找令牌。如果您想添加自定义令牌,例如" LTY"您还需要将其添加到本地格式化令牌列表中:
var localFormattingTokens = /(\[[^\[]*\])|(\\)?(LTS|LT|LL?L?L?|l{1,4})/g;
将更改为(LTY已添加):
var localFormattingTokens = /(\[[^\[]*\])|(\\)?(LTY|LTS|LT|LL?L?L?|l{1,4})/g;
并使用新令牌更新默认长日期格式:
var defaultLongDateFormat = {
LTY : 'MM/DD HH:mm', // format for new token
LTS : 'h:mm:ss A',
LT : 'h:mm A',
L : 'MM/DD/YYYY',
LL : 'MMMM D, YYYY',
LLL : 'MMMM D, YYYY h:mm A',
LLLL : 'dddd, MMMM D, YYYY h:mm A'
};
然后,如果你想要其他格式:
moment.updateLocale('en', {
longDateFormat : {
LTY: 'MM/DD HH:mm', // new format for token here
LT: "h:mm A",
LTS: "h:mm:ss A",
L: "MM/DD/YYYY",
LL: "MMMM Do YYYY",
LLL: "MMMM Do YYYY LT",
LLLL: "dddd, MMMM Do YYYY LT"
}
});
最后:
var x = moment().format('LTY');
但您必须检查其他代码的用途。此外,每次更新moment.js源时,您都必须应用相同的更改,无法使用CDN,并且您的代码无法使用标准的moment.js库移植到其他网站。< / p>
所以坚持 updateLocale 的做事方式。或者只是做:
var LTY = 'MM/DD HH:mm';
var d = new moment().format(LTY);
console.log(d)
&#13;
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.14.1/moment.js"></script>
&#13;
你已经完成了。
请注意使用&#34; locale&#34;这是用词不当。格式化首选项与用户所在的位置(即他们的区域设置)无关,并且&#34; en&#34;是一种在大量语言环境中使用的语言,它们对如何格式化日期有着截然不同的偏好。