解析日期,不带时区javascript

2020/11/13 11:22 · javascript ·  · 0评论

我想在JavaScript中解析没有时区的日期。我努力了:

new Date(Date.parse("2005-07-08T00:00:00+0000"));

返回时间:2005年7月8日星期五,格林尼治标准时间+0200 (欧洲中部夏令时间)

new Date(Date.parse("2005-07-08 00:00:00 GMT+0000"));

返回相同的结果

new Date(Date.parse("2005-07-08 00:00:00 GMT-0000"));

返回相同的结果

我想解析时间:

  1. 没有时区。

  2. 无需调用构造函数Date.UTC或新的Date(年,月,日)。

  3. 只需将字符串简单地传递到Date构造函数即可(无需原型方法)。

  4. 我必须提供Date对象,而不是String

日期已正确解析,只是toString会将其转换为您的本地时区:

let s = "2005-07-08T11:22:33+0000";
let d = new Date(Date.parse(s));

// this logs for me 
// "Fri Jul 08 2005 13:22:33 GMT+0200 (Central European Summer Time)" 
// and something else for you

console.log(d.toString()) 

// this logs
// Fri, 08 Jul 2005 11:22:33 GMT
// for everyone

console.log(d.toUTCString())

Javascript Date对象是时间戳-自时代以来仅包含毫秒数。Date对象中没有时区信息。此时间戳表示哪个日历日期(天,分钟,秒)取决于解释(to...String方法之一)。

上面的示例显示日期已正确解析-也就是说,它实际上包含与GMT中的“ 2005-07-08T11:22:33”相对应的毫秒数。

我有同样的问题。我以字符串形式获取日期,例如:'2016-08-25T00:00:00',但是我需要具有正确时间的Date对象。要将String转换为对象,我使用getTimezoneOffset:

var date = new Date('2016-08-25T00:00:00')
var userTimezoneOffset = date.getTimezoneOffset() * 60000;
new Date(date.getTime() - userTimezoneOffset);

getTimezoneOffset()将返回以太坊的负值或正值。必须减去它才能在世界上的每个位置工作。

我遇到了同样的问题,然后想起了关于我正在从事的旧项目以及他们如何处理此问题的一些小问题。当时我不了解,也没真正在乎,直到我自己遇到问题

var date = '2014-01-02T00:00:00.000Z'
date = date.substring(0,10).split('-')
date = date[1] + '-' + date[2] + '-' + date[0]

new Date(date) #Thu Jan 02 2014 00:00:00 GMT-0600

无论出于什么原因,将日期传递为'01 -02-2014'都会将时区设置为零,并忽略用户的时区。这可能是Date类中的偶然现象,但是它存在于一段时间之前,并且一直存在到今天。它似乎可以跨浏览器工作。自己尝试一下。

该代码是在一个时区非常重要的全球项目中实现的,但是查看日期的人并不关心引入它的确切时间。

Date对象本身将包含时区无论如何,返回的结果是一个默认的方式将其转换为字符串的效果。即您不能创建没有时区的日期对象但是您可以做的是Date通过创建自己对象来模仿对象的行为但是,最好将其移交给moment.js之类的

简单的解决方案

const handler1 = {
  construct(target, args) {
    let newDate = new target(...args);
    var tzDifference = newDate.getTimezoneOffset();
    return new target(newDate.getTime() + tzDifference * 60 * 1000);
  }
};

Date = new Proxy(Date, handler1);

您可以使用此代码

var stringDate = "2005-07-08T00:00:00+0000";
var dTimezone = new Date();
var offset = dTimezone.getTimezoneOffset() / 60;
var date = new Date(Date.parse(stringDate));
date.setHours(date.getHours() + offset);

javascript中的日期只是使其内部保持简单。因此日期时间数据存储在UTC Unix纪元(毫秒或ms)中。

如果您希望地球上的任何时区都没有固定的“固定”时间,则可以调整UTC时间以匹配您当前的本地时区并保存。取回时,无论您身在本地时区如何,它都会根据保存该时间的UTC时间显示该时间,并添加本地时区偏移量以获取“固定”时间。

保存日期(以毫秒为单位)

toUTC(datetime) {
  const myDate = (typeof datetime === 'number')
    ? new Date(datetime)
    : datetime;

  if (!myDate || (typeof myDate.getTime !== 'function')) {
    return 0;
  }

  const getUTC = myDate.getTime();
  const offset = myDate.getTimezoneOffset() * 60000; // It's in minutes so convert to ms
  return getUTC - offset; // UTC - OFFSET
}

检索/显示日期(以毫秒为单位)

fromUTC(datetime) {
  const myDate = (typeof datetime === 'number')
    ? new Date(datetime)
    : datetime;

  if (!myDate || (typeof myDate.getTime !== 'function')) {
    return 0;
  }

  const getUTC = myDate.getTime();
  const offset = myDate.getTimezoneOffset() * 60000; // It's in minutes so convert to ms
  return getUTC + offset; // UTC + OFFSET
}

那么你就可以:

const saveTime = new Date(toUTC(Date.parse("2005-07-08T00:00:00+0000")));
// SEND TO DB....

// FROM DB...
const showTime = new Date(fromUTC(saveTime));

由于显示日期(例如,以当地时间显示)时确实是格式问题,所以我喜欢使用new(ish)Intl.DateTimeFormat对象执行格式化,因为它更明确,并提供更多输出选项:

const dateOptions = { timeZone: 'UTC', month: 'long', day: 'numeric', year: 'numeric' };

const dateFormatter = new Intl.DateTimeFormat('en-US', dateOptions);
const dateAsFormattedString = dateFormatter.format(new Date('2019-06-01T00:00:00.000+00:00'));

console.log(dateAsFormattedString) // "June 1, 2019"

如图所示,将timeZone设置为'UTC'不会执行本地转换。另外,它还允许您创建更多优化的输出。您可以Mozilla-Intl.DateTimeFormat中阅读有关Intl.DateTimeFormat对象的更多信息

编辑:

无需创建新Intl.DateTimeFormat对象即可实现相同的功能只需将语言环境和日期选项直接传递给toLocaleDateString()函数即可。

const dateOptions = { timeZone: 'UTC', month: 'long', day: 'numeric', year: 'numeric' };
const myDate = new Date('2019-06-01T00:00:00.000+00:00');
today.toLocaleDateString('en-US', dateOptions); // "June 1, 2019"

只是一般性的注释。一种保持灵活性的方法。

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Date

我们可以使用getMinutes(),但在前9分钟内它仅返回一个数字。

let epoch = new Date() // Or any unix timestamp

let za = new Date(epoch),
    zaR = za.getUTCFullYear(),
    zaMth = za.getUTCMonth(),
    zaDs = za.getUTCDate(),
    zaTm = za.toTimeString().substr(0,5);

console.log(zaR +"-" + zaMth + "-" + zaDs, zaTm)
Date.prototype.getDate()
    Returns the day of the month (1-31) for the specified date according to local time.
Date.prototype.getDay()
    Returns the day of the week (0-6) for the specified date according to local time.
Date.prototype.getFullYear()
    Returns the year (4 digits for 4-digit years) of the specified date according to local time.
Date.prototype.getHours()
    Returns the hour (0-23) in the specified date according to local time.
Date.prototype.getMilliseconds()
    Returns the milliseconds (0-999) in the specified date according to local time.
Date.prototype.getMinutes()
    Returns the minutes (0-59) in the specified date according to local time.
Date.prototype.getMonth()
    Returns the month (0-11) in the specified date according to local time.
Date.prototype.getSeconds()
    Returns the seconds (0-59) in the specified date according to local time.
Date.prototype.getTime()
    Returns the numeric value of the specified date as the number of milliseconds since January 1, 1970, 00:00:00 UTC (negative for prior times).
Date.prototype.getTimezoneOffset()
    Returns the time-zone offset in minutes for the current locale.
Date.prototype.getUTCDate()
    Returns the day (date) of the month (1-31) in the specified date according to universal time.
Date.prototype.getUTCDay()
    Returns the day of the week (0-6) in the specified date according to universal time.
Date.prototype.getUTCFullYear()
    Returns the year (4 digits for 4-digit years) in the specified date according to universal time.
Date.prototype.getUTCHours()
    Returns the hours (0-23) in the specified date according to universal time.
Date.prototype.getUTCMilliseconds()
    Returns the milliseconds (0-999) in the specified date according to universal time.
Date.prototype.getUTCMinutes()
    Returns the minutes (0-59) in the specified date according to universal time.
Date.prototype.getUTCMonth()
    Returns the month (0-11) in the specified date according to universal time.
Date.prototype.getUTCSeconds()
    Returns the seconds (0-59) in the specified date according to universal time.
Date.prototype.getYear()
    Returns the year (usually 2-3 digits) in the specified date according to local time. Use getFullYear() instead. 

(new Date().toString()).replace(/ \w+-\d+ \(.*\)$/,"")

这将有输出:Tue Jul 10 2018 19:07:11

(new Date("2005-07-08T11:22:33+0000").toString()).replace(/ \w+-\d+ \(.*\)$/,"")

这将具有输出:Fri Jul 08 2005 04:22:33

注意:返回的时间将取决于您当地的时区

这是我针对此问题想出的解决方案,对我有用。


使用的库:带有普通javascript Date类的momentjs。

步骤1.将String date转换为moment对象(PS:只要toDate()不调用method,moment就会保留原始的日期和时间):

const dateMoment = moment("2005-07-08T11:22:33+0000");

步骤2.从先前创建的矩对象中提取hoursminutes值:

  const hours = dateMoment.hours();
  const mins = dateMoment.minutes();

步骤3.将时间转换为日期(PS:这将根据您的浏览器/机器的时区来更改原始日期,但请不要担心,请阅读步骤4。):

  const dateObj = dateMoment.toDate();

步骤4.手动设置步骤2中提取的小时和分钟。

  dateObj.setHours(hours);
  dateObj.setMinutes(mins);

步骤5.
dateObj现在将显示原始日期,没有任何时区差异。因为我们手动设置原始的小时和分钟,所以即使是夏令时更改也不会对日期对象产生任何影响。

希望这可以帮助。

默认情况下,日期解析存在一些固有的问题,这些问题无法很好地解决。

-人类可读的日期中包含隐含的时区

-网络上有许多广泛使用的日期格式,其中含糊不清

要解决这些问题既简单又干净,需要使用以下功能:

>parse(whateverDateTimeString,expectedDatePattern,timezone)
"unix time in milliseconds"

我已经搜索过了,但是什么也没找到!

所以我创建了:https :
//github.com/zsoltszabo/timestamp-grabber

请享用!

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

文件下载

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

上一篇:
下一篇:

评论已关闭!