我正在使用angular-moment中的amCalendar过滤器来显示视图中的时刻。
amCalendar过滤器不接受Date作为类型。我创建了这个函数,它返回短日期ISO字符串,传递日期参数:
function toShortISO(d){
var date;
date instanceof Date?
date = d:
date = toDate(d);
function pad(n) {return n<10 ? '0'+n : n}
return date.getUTCFullYear()
+ pad( date.getUTCMonth() + 1 )
+ pad( date.getUTCDate() )
+ 'T' + pad( date.getUTCHours() )
+ pad( date.getUTCMinutes() )
+ pad( date.getUTCSeconds() )
+ 'Z';
}
传递日期,此函数返回20150905T060000Z
(每个示例)。现在我可以将amCalendar过滤器应用于此字符串。
在视图中按预期显示“今天凌晨2:30”,但控制台中出现此警告:
参考:https://github.com/moment/moment/issues/1407
在参考说明中有必要创建一个瞬间对象来解决这个问题,但我不知道如何,我认为示例是针对nodeJS而不是angularJS。
我试试这个:
function toShortISO(d){
return moment(d.toISOString());
}
但是不要工作。
谢谢!
答案 0 :(得分:2)
要摆脱警告,您需要:
传入日期字符串的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 Date对象,然后将其传递给Moment:
moment(new Date('Wed, 23 Apr 2014 09:54:51 +0000'));
最后一个选项是Moment目前支持的内置回退,其中包含已弃用的控制台警告。他们表示,他们不会在未来版本中支持这种后备。他们解释说使用新的日期('我的约会')太难以预测了。
基本上你需要告诉你如何解析你的日期格式,如下所示:
var parsedDate = moment.utc("150423160509", "YYMMDDHHmmss");
var a = parsedDate.tz("Asia/Taipei");
// I'm assuming you meant HH:mm:ss here
console.log( a.format("YYYY-MM-DD HH:mm:ss") );