问题描述
我的日期是用户浏览器时区中给定日期的开始,但是我需要使用date-fns将其转换为另一个时区中的开始日期。
我有个约会:
const date = new Date("2020-10-13"); // Tue Oct 13 2020 00:00:00 GMT-0400 (Eastern Daylight Time)
我需要将其转换为"America/Chicago"
时区中的一天的开始。
const timeZone = "America/Chicago";
// Need to convert a date object
// Tue Oct 13 2020 00:00:00 GMT-0400 (Eastern Daylight Time)
// to
// Tue Oct 13 2020 00:00:00 GMT-0500 (Central Daylight Time)
// and all I'm given is the timeZone value.
解决方法
要获得对date-fns的时区支持,您将需要date-fns-tz附加模块。
然后您可以执行以下操作:
import { zonedTimeToUtc } from 'date-fns-tz';
const dt = zonedTimeToUtc('2020-10-13','America/Chicago');
结果将是一个Date
对象,该对象代表给定时区的午夜。
请记住,Date
对象本身总是 基于UTC。因此,您将无法获得位于不同时区的Date
对象。
此外,您应该如图所示将字符串传递到zonedTimeToUtc
函数中。您应该不将其传递给Date
对象。如评论中所述,ECMAScript规范指出,应将仅日期的字符串值解析为 UTC 。但是,仍有一些实现未正确遵循规范。因此,应避免使用Date
对象构造函数来解析字符串。