如何在reactjs中修复moment.js?

时间:2019-02-07 02:41:06

标签: reactjs momentjs

我正在使用moment.js并收到此错误:

  

弃用警告:提供的值不在公认的RFC2822中或   ISO格式。的建设回落到js Date(),这不是   在所有浏览器和版本中均可靠。非RFC2822 / ISO日期   不鼓励使用这些格式,并将在以后的主要版本中将其删除   发布。请参阅   http://momentjs.com/guides/#/warnings/js-date/了解更多信息。   参数:[0] _isAMomentObject:true,_isUTC:false,_useU

在我的react组件中,我有:

const sortTasks = (first, second) => moment(first.endDate).diff(second.endDate);

first.enddate =“ 2018年12月20日”

如何避免在控制台中出现此警告?

1 个答案:

答案 0 :(得分:1)

一种替代方法是,通过向moment函数提供第二个参数,来告知moment.js使用的日期格式。

“ 2018年12月20日”的格式为DD MMM YYYY”。 如果两个日期的格式相同,则应写

const sortTasks = (first, second) => 
    moment(first.endDate, "DD MMM YYYY").diff(moment(second.endDate, "DD MMM YYYY"));

请注意,另一个日期也以非标准格式表示,因此也明确地转换为片刻。

您可以在the moment.js documentation about parsing中查看详细信息。


如果您想找出以天为单位的差异,例如年/月/日,则可以使用moment.duration。选中the moment.js documentation about this feature

例如要获得两个日期(例如date1date2)之间的年,月和日的数量,我们可以进行如下操作(假设date1date2之前):

const theDuration = moment.duration(date2, date1);
const yearsElapsed = theDuration.years();
const monthsElapsed = theDuration.months();
const daysElapsed = theDuration.days();


希望对您有所帮助-卡洛斯(Carlos)