如何在moment.js中设置用于解析的语言环境?

时间:2019-06-06 15:23:07

标签: javascript date momentjs

不幸的是,我没有在文档中找到答案,所以...

例如,我输入了日期:“ 09/01/2017”。我不知道,它是DD / MM / YYYY或MM / DD / YYYY,但是我知道用户的语言环境。我可以得到类似下面的内容吗?

let date   = "09/01/2017",
    locale = "en_US",// or "en_AU"
    result = moment(date, locale).format("DD MMM YYYY");
// 01 Sep 2017
// 09 Jan 2017

还是我需要写地图,然后将格式设置为“时刻”?

let map =
    {
        en_US: 'DD/MM/YYYY',
        en_AU: 'MM/DD/YYYY',
        // ...
    },
    date   = "09/01/2017",
    locale = "en_US",// or "en_AU"
    result = moment(date, map[locale]).format("DD MMM YYYY");
// 01 Sep 2017
// 09 Jan 2017

谢谢

2 个答案:

答案 0 :(得分:3)

您可以使用moment.localeData()longDateFormat('L')来获取特定于语言环境的令牌。

这里有一个现场样本:

let date   = "09/01/2017";
let locale = "en_US";
let localeFormat =  moment.localeData(locale).longDateFormat('L');
let result = moment(date, localeFormat).format("DD MMM YYYY");
console.log(result); // 01 Sep 2017

locale = "en_AU";
localeFormat =  moment.localeData(locale).longDateFormat('L');
result = moment(date, localeFormat).format("DD MMM YYYY");
console.log(result); // 09 Jan 2017
<script src="https://cdnjs.cloudflare.com/ajax/libs/moment.js/2.24.0/moment-with-locales.min.js"></script>

答案 1 :(得分:0)

我会使用普通的JS来基于本地来提取月份,使用moment将月份格式化为MMM,然后将它们加入。

var locale = 'en_AU'

var date = '09/01/2019'.split('/')

if (locale === 'en_AU') {
    var monthFormatted = moment(date[0]).format('MMM')
    date = [date[1], monthFormatted, date[2]].join(' ')
}

else {
    var monthFormatted = moment(date[1]).format('MMM')
    date = [date[0], monthFormatted, date[2]].join(' ')
}

console.log(date)
// 09 Jan 2019 or 01 Sep 2019