我正在使用以下代码使用 moment.js 将服务器端日期时间转换为本地时间。
moment(moment('Wed, 23 Apr 2014 09:54:51 +0000').format('lll')).fromNow()
但我得到:
弃用警告:时刻构造回退到 js 日期。这是不鼓励的,并将在即将发布的主要版本中删除。请参阅https://github.com/moment/moment/issues/1407了解更多信息。
好像摆脱不了!我该如何解决?
我正在使用以下代码使用 moment.js 将服务器端日期时间转换为本地时间。
moment(moment('Wed, 23 Apr 2014 09:54:51 +0000').format('lll')).fromNow()
但我得到:
弃用警告:时刻构造回退到 js 日期。这是不鼓励的,并将在即将发布的主要版本中删除。请参阅https://github.com/moment/moment/issues/1407了解更多信息。
好像摆脱不了!我该如何解决?
要消除警告,您需要:
传入日期字符串的 ISO 格式版本:
moment('2014-04-23T09:54:51');
传入您现在拥有的字符串,但告诉 Moment 字符串的格式:
moment('Wed, 23 Apr 2014 09:54:51 +0000', 'ddd, DD MMM YYYY HH:mm:ss ZZ');
将您的字符串转换为 JavaScript 日期对象,然后将其传递给 Moment:
moment(new Date('Wed, 23 Apr 2014 09:54:51 +0000'));
最后一个选项是 Moment 目前支持的内置回退,带有已弃用的控制台警告。他们说他们不会在未来的版本中支持这种回退。他们解释说使用new Date('my date')
太不可预测了。
作为替代方案,您可以通过设置禁止显示弃用警告 moment.suppressDeprecationWarnings = true;
moment
内部的日期构造在new Date()
javascript 中使用。该new Date()
结构可识别所有浏览器中RFC2822或ISO格式的日期字符串。当构造moment
日期不是这些格式的对象时,会抛出弃用警告。
尽管抛出了弃用警告,但对于某些格式,该moment
对象将在 Chrome 中成功构建,但在 Firefox 或 Safari 中无法成功构建。因此,在 Chrome 中处理日期可能会产生预期的结果(并非总是如此)并抛出Invalid Date
其他结果。
考虑, 02.02.2018
,
铬 - moment("02.02.2018")._d
->Fri Feb 02 2018 00:00:00 GMT+0530 (India Standard Time)
火狐 - moment("02.02.2018")._d
->Invalid Date
Safari - moment("02.02.2018")._d
->Invalid Date
因此,moment.js
在不使用推荐/标准格式的情况下,您需要自担风险。
为了抑制弃用警告,
moment
构建的日期格式。例子 : moment("02.05.2018", "DD.MM.YYYY").format("DD MM YYYY");
示例:moment("2018-02-01T18:30:00.000Z")
- ISO 格式
moment("Thu, 01 Feb 2018 18:30:00 GMT")
- RFC2822 格式 - Github 中的格式
moment.suppressDeprecationWarnings = true;
我建议立即覆盖输入回退。
moment.createFromInputFallback=function (config){
config._d = new Date(config._i);
}
由于 (3) 将抑制所有警告,(4) 将仅抑制日期构造回退。使用(4),你会得到Invalid Date
internalnew Date()
被使用,其他的deprecations可以在console中看到,所以moment可以升级或者在应用中替换deprecated方法。
如果您的日期是从 API 传递给您的string
(如我的问题),您可以暂时使用过滤器将字符串转换为日期。这将处理当前的施工警告。
$scope.apiDate = 10/29/2017 18:28:03";
angular.module('myApp').filter('stringToDate', function() {
return function(value) {
return Date.parse(value);
};
});
将其添加到视图中:
{{apiDate | stringToDate | amDateFormat:'ddd, MMM DD'}}
如上述答案所示。提供日期格式应该有效。
为什么我会收到带有以下代码行的弃用消息。我认为 String + 格式应该可以解决这个问题。moment.tz('2015:08:20 14:33:20', 'YYYY:MM:DD HH:mm:ss', 'America/New_York')
. 另外,请不要我无法控制所提供的日期格式。我知道我可以自己将其转换为'YYYY-MM-DDTHH:mm:ss'
moment 不显示弃用消息。但是,根据文档,这行代码应该可以工作。这是我看到的弃用消息。
“弃用警告:提供的值不是公认的 RFC2822 或 ISO 格式。时刻构造回退到 js Date(),这在所有浏览器和版本中都不可靠。不鼓励使用非 RFC2822/ISO 日期格式,并将在即将发布的主要版本。请参阅 http://momentjs.com/guides/#/warnings/js-date/了解更多信息。”