在mongoose模式的默认日期值中将月份添加到当前日期

时间:2017-12-20 13:43:45

标签: javascript node.js mongodb date mongoose

我们有一个像这样的猫鼬模式:

var sampleSchema = new Schema({
    fieldABC: String,
    expireAfter1Month:{
        type: Date,
        default: new Date() + 1 month
    }
});

expireAfter1Month的默认值应设置为一个月后的日期值。

我有这些:

如何在mongoose架构的默认日期值中将月份添加到当前日期?

可能我可以这样做

default: +new Date() + 30*24*60*60*1000

但是,我想知道是否有更好/优化的方法?

1 个答案:

答案 0 :(得分:4)

基于您发布的其中一个链接的答案

即。 https://stackoverflow.com/a/30525690/5053002

var minuteFromNow = function(){
    var timeObject = new Date();
    timeObject.setTime(timeObject.getTime() + 1000 * 60);
    return timeObject;
};

new Schema({
    date: { type: Date, default: minuteFromNow }
})

如果你想要,例如,从1月29日/ 30日/ 31日到2月28日(当然是闰年29日),从3月31日,5月,8月或10月到4月30日,一个月,分别是6月,9月和11月,那么你需要更多的逻辑

这样的东西
function oneMonthFromNow() {
    var d = new Date();
    var targetMonth = d.getMonth() + 1;
    d.setMonth(targetMonth);
    if(d.getMonth() !== targetMonth % 12) {
        d.setDate(0); // last day of previous month
    }
    return d;
}
new Schema({
    date: { type: Date, default: oneMonthFromNow}
})

为了说明这将如何处理月末,以下是相同的代码,除了d是传入的任意日期,而不是使用now - 以显示这将如何工作



function oneMonthFromNow(d) {
    var targetMonth = d.getMonth() + 1;
    d.setMonth(targetMonth);
    if(d.getMonth() !== targetMonth % 12) {
        d.setDate(0); // last day of previous month
    }
    return d;
}
console.log(oneMonthFromNow(new Date('2017-10-31T00:00:00Z'))); // 30 November
console.log(oneMonthFromNow(new Date('2017-11-30T00:00:00Z'))); // 30 December
console.log(oneMonthFromNow(new Date('2017-12-31T00:00:00Z'))); // 31 January
console.log(oneMonthFromNow(new Date('2018-01-31T00:00:00Z'))); // 28 February
console.log(oneMonthFromNow(new Date('2018-02-28T00:00:00Z'))); // 28 March




您的评论(在我发布此答案之后添加:p)建议从1月31日开始的一个月应该是3月2日,即总是只添加30天,在这种情况下您自己的建议

new Schema({
    date: { type: Date, default: +new Date() + 30*24*60*60*1000}
})

会很理想