Я пытаюсь обновить var внутри цикла, который затем возвращается к обещанию.Но VAR не удается обновить.До сих пор я пробовал это,
var queryPromise = cronie.find({}).
where('id').equals(req.user._id).
exec(); //mongoose promise
queryPromise.then(function(timer) {
for (var i = 0, len = timer.length; i < len; i++) {
x = moment.unix(timer[i].nextTick).format('dddd, MMMM Do, YYYY h:mm:ss A'); //convert to human;
console.log(x);
timer[i].nextTick = x;
console.log(timer[i].nextTick);
}
return timer;
}).then(function(timer) {
res.render('dash.ejs', {
user: req.user,
timer: timer
});
});
});
Это выходные данные:
0|server | Monday, May 21st, 2018 11:00:00 PM
0|server | 1526943600
0|server | Monday, May 21st, 2018 7:28:22 PM
0|server | 1526930902
0|server | Monday, May 21st, 2018 7:28:22 PM
0|server | 1526930902
0|server | Monday, May 21st, 2018 7:28:22 PM
0|server | 1526930902
0|server | Monday, May 21st, 2018 7:28:22 PM
0|server | 1526930902
Но timer[i].nextTick
остается неизменным.Как обновить его перед отправкой на рендеринг, чтобы пользователи могли видеть человеческое время вместо штампа?
ОБНОВЛЕНИЕ Срез массива таймеров
0|server | { _id: 5b031dd6c0d99f79946f263f,
0|server | id: '5b031dd5c0d99f79946f263a',
0|server | lastTick: 1526930902,
0|server | nextTick: 1526930902,
0|server | lastUpdate: 1526930902,
0|server | __v: 0,
0|server | timerStatus: false,
0|server | emailStatus: false }
ОБНОВЛЕНИЕ 2
добавление
timer[i].date = moment.unix(timer[i].nextTick).format('dddd, MMMM Do, YYYY h:mm:ss A');
с последующим изменением ejs на timer.date works
.Но присвоение nextTick
все еще не делает.