Moment.js转换为日期对象

2020/09/21 20:31 · javascript ·  · 0评论

使用Moment.js,我无法将正确的矩对象转换为具有时区的日期对象。我找不到正确的日期。

例:

var oldDate = new Date(),
    momentObj = moment(oldDate).tz("MST7MDT"),
    newDate = momentObj.toDate();
console.log("start date " + oldDate)
console.log("Format from moment with offset " + momentObj.format())
console.log("Format from moment without offset " + momentObj.utc().format())
console.log("(Date object) Time with offset " + newDate)
console.log("(Date object) Time without offset "+ moment.utc(newDate).toDate())

使用此方法可以将矩对象转换为日期对象:

http://momentjs.com/docs/#/displaying/as-javascript-date/

moment().toDate();

产量:

Tue Nov 04 2014 14:04:01 GMT-0600 (CST)

只要您使用所需区域的数据初始化了moment-timezone,您的代码就会按预期工作。

您正在正确地将力矩转换为时区,这反映在的输出的第二行中momentObj.format()

切换到UTC不仅会减少偏移量,还会改回到UTC时区。如果要执行此操作,则根本不需要原始.tz()呼叫。你可以做moment.utc()

也许您只是想更改输出格式字符串?如果是这样,只需为该format方法指定所需的参数即可

momentObj.format("YYYY-MM-DD HH:mm:ss")

关于代码的最后一行-当您Date使用时返回一个对象时toDate(),您将放弃moment.js的行为并返回到JavaScript的行为。JavaScript Date对象将始终在运行它的计算机的本地时区中打印。瞬间,js对此无能为力。

其他一些小事情:

  • 尽管构造函数可以使用Date,但通常最好不要使用。对于“ now”,请不要使用moment(new Date())而是使用moment()两者都可以,但是不必要地多余。如果要从字符串中进行解析,请将该字符串直接传递给moment。不要试图先解析它Date您会发现瞬间的解析器更加可靠。

  • 像这样的时区MST7MDT是出于向后兼容的原因。它们源自POSIX样式的时区,并且其中只有少数位于TZDB数据中。除非绝对必要,否则应使用诸如的键America/Denver

.toDate 并没有真正为我工作,所以,这就是我所做的:

futureStartAtDate = new Date(moment().locale("en").add(1, 'd').format("MMM DD, YYYY HH:MM"))

希望这可以帮助

由于momentjs无法控制javascript日期对象,因此我找到了解决方法。

const currentTime = new Date();    
const convertTime = moment(currentTime).tz(timezone).format("YYYY-MM-DD HH:mm:ss");
const convertTimeObject = new Date(convertTime);

这将为您提供一个带有转换时间的javascript date对象

我需要在日期字符串中包含时区信息。我本来是用的,moment.tz(dateStr, 'America/New_York').toString();但是后来我开始收到有关将该字符串反馈回去的错误。

我尝试了,moment.tz(dateStr, 'America/New_York').toDate();但随后却丢失了所需的时区信息。

返回具有时区的可用日期字符串的唯一解决方案moment.tz(dateStr, 'America/New_York').format();

let dateVar = moment('any date value');
let newDateVar = dateVar.utc().format();

好干净!!!

要转换任何日期,例如utc:

moment( moment().utc().format( "YYYY-MM-DD HH:mm:ss" )).toDate()

尝试(无format步骤)

new Date(moment())

这个问题有点晦涩。我会尽力解释这一点。首先,您应该了解如何使用moment-timezone根据这里的答案 TypeError:moment()。tz不是一个函数,您必须从moment-timezone而不是默认矩中导入moment(当然,您必须首先npm安装moment-timezone!)。为清楚起见,

const moment=require('moment-timezone')//import from moment-timezone

现在,为了使用时区功能,请使用moment.tz(“ date_string / moment()”,“ time_zone”)有关更多详细信息,请访问https://momentjs.com/timezone/)。此函数将返回具有特定时区的矩对象。为清楚起见,

var newYork= moment.tz("2014-06-01 12:00", "America/New_York");/*this code will consider NewYork as the timezone.*/

现在,当您尝试将带有矩的toDate()(ISO 8601格式转换)的newYork(矩对象)转换为英国格林威治时间时。有关更多详细信息,请浏览有关UTC的本文https://www.nhc.noaa.gov/aboututc.shtml但是,如果您只希望采用这种格式的本地时间(根据本示例,则为纽约时间),只需将带有arg true的.utc(true)方法添加到moment对象。为清楚起见,

newYork.toDate()//will give you the Greenwich ,UK, time.

newYork.utc(true).toDate()//will give you the local time. according to the moment.tz method arg we specified above, it is 12:00.you can ofcourse change this by using moment()

简而言之,moment.tz会考虑您指定的时区,并将本地时间与格林威治时间进行比较,以得出结果。我希望这是有用的。

此刻已更新了截至2018年6月6日的js库。

var newYork    = moment.tz("2014-06-01 12:00", "America/New_York");
var losAngeles = newYork.clone().tz("America/Los_Angeles");
var london     = newYork.clone().tz("Europe/London");

newYork.format();    // 2014-06-01T12:00:00-04:00
losAngeles.format(); // 2014-06-01T09:00:00-07:00
london.format();     // 2014-06-01T17:00:00+01:00

如果您可以自由使用Angular5 +,则最好使用此处的datePipe功能,而不要使用此处的时区功能。我必须使用moment.js,因为我的项目仅限于Angular2。

本文地址:http://javascript.askforanswer.com/moment-jszhuanhuanweiriqiduixiang.html
文章标签: ,  
版权声明:本文为原创文章,版权归 javascript 所有,欢迎分享本文,转载请保留出处!

文件下载

老薛主机终身7折优惠码boke112

上一篇:
下一篇:

评论已关闭!