我有以下代码
var c = new Date(Date.parse("2011-06-21T14:27:28.593Z"));
console.log(c);
在 Chrome 上,它会在控制台上正确打印日期。在 Safari 中它失败了。谁是正确的,更重要的是处理这个问题的最佳方法是什么?
我有以下代码
var c = new Date(Date.parse("2011-06-21T14:27:28.593Z"));
console.log(c);
在 Chrome 上,它会在控制台上正确打印日期。在 Safari 中它失败了。谁是正确的,更重要的是处理这个问题的最佳方法是什么?
你不能真正使用 Date.parse。我建议你使用: new Date (year, month [, date [, hours [, minutes [, seconds [, ms ] ] ] ] ] )
要拆分字符串,您可以尝试
var s = '2011-06-21T14:27:28.593Z';
var a = s.split(/[^0-9]/);
//for (i=0;i<a.length;i++) { alert(a[i]); }
var d=new Date (a[0],a[1]-1,a[2],a[3],a[4],a[5] );
alert(s+ " "+d);
我的类似问题是由 Safari 不知道如何以 RFC 822 时区格式读取时区造成的。我能够通过使用 ISO 8601 格式来解决这个问题。如果您可以控制日期格式,我就可以使用 java 的 SimpleDateFormat "yyyy-MM-dd'T'HH:mm:ss.sssXXX" 为我生成,即。“2018-02-06T20:00:00.000+04:00”。无论出于何种原因,Safari 都无法读取“2018-02-06T20:00:00.000+0400”,请注意时区格式中缺少冒号。
// Works
var c = new Date("2018-02-06T20:00:00.000+04:00"));
console.log(c);
// Doesn't work
var c = new Date("2018-02-06T20:00:00.000+0400"));
console.log(c);
Date.parse
根据这个问题的其他答案,我倾向于避免。它似乎不是可靠处理日期的可移植方式。
相反,我使用了类似下面的函数。这使用 jQuery 将字符串数组映射到数字数组,但这是一个非常容易删除/更改的依赖项。我还包括我认为合理的默认值,以允许您解析2007-01-09
和2007-01-09T09:42:00
使用相同的函数。
function dateFromString(str) {
var a = $.map(str.split(/[^0-9]/), function(s) { return parseInt(s, 10) });
return new Date(a[0], a[1]-1 || 0, a[2] || 1, a[3] || 0, a[4] || 0, a[5] || 0, a[6] || 0);
}
我在几个浏览器中检查过,是的,safari 返回invalid date
. 顺便说一句,您不必Date.parse
在这里使用,也可以使用new Date([datestring])
。Safari 显然需要对您提供的日期字符串进行更多格式化。如果将“-”替换为“/”,删除 T 和点 (.593Z) 之后的所有内容,它将为您提供有效日期。此代码经过测试并在 Safari 中工作
var datestr = '2011-06-21T14:27:28.593Z'.split(/[-T.]/);
var safdat = new Date( datestr.slice(0,3).join('/')+' '+datestr[3] );
或使用String.replace(...)
:
new Date("2016-02-17T00:05:01+0000".replace(/-/g,'/').replace('T',' ').replace(/(\..*|\+.*/,""))
我使用以下函数来解析带时区的日期。Chrome 和 Safari 都可以正常工作:
function parseDate(date) {
const parsed = Date.parse(date);
if (!isNaN(parsed)) {
return parsed;
}
return Date.parse(date.replace(/-/g, '/').replace(/[a-z]+/gi, ' '));
}
console.log(parseDate('2017-02-09T13:22:18+0300')); // 1486635738000 time in ms