我有一个开始日期字符串“20.03.2014”,我想用moment.js添加5天,但我没有在警报窗口中得到新的日期“25.03.2014”。

这里是我的javascript代码:

startdate = "20.03.2014";
var new_date = moment(startdate, "DD-MM-YYYY").add("DD-MM-YYYY", 5);

alert(new_date);

这里是我的jsfiddle: http://jsfiddle.net/jbgUt/1/

我怎么解决这个问题?

我喜欢这个字符串格式“25.03.2014”

希望有人能帮助我。


当前回答

函数add()返回旧日期,但更改原始日期:)

startdate = "20.03.2014";
var new_date = moment(startdate, "DD.MM.YYYY");
new_date.add(5, 'days');
alert(new_date);

其他回答

函数add()返回旧日期,但更改原始日期:)

startdate = "20.03.2014";
var new_date = moment(startdate, "DD.MM.YYYY");
new_date.add(5, 'days');
alert(new_date);

更新:

startdate = "20.03.2014";
var new_date = moment(startdate, "DD-MM-YYYY").add(5,'days');

alert(new_date)

如果在函数中添加X时间后出现格式问题,请尝试以下格式:

startDate = moment(startDate)。add(1天).format(“YYYY-MM-DD”);

而不是:

startDate = moment(startDate, “YYYY-MM-DD”).add(1, “days”);

最后一个版本将时间附加到返回的数据,而format方法则不这样做,而是直接返回YYYY-MM-DD。

将https://momentjs.com/downloads/moment-with-locales.js添加到HTML页面 var todayDate = moment().format('DD-MM-YYYY') 然后 var dueDate = moment().add(15,'days').format('DD-MM-YYYY')//为当前日期添加15天。

点2和3是用在你的jquery代码…

如果我们想使用当前日期或当前日期:

var new_date = moment(moment(), "MM-DD-YYYY").add(7, 'days')
alert(new_date);