Динамическая дата и время с moment.js и setInterval
Я пытаюсь выяснить, как я могу отображать динамическую дату и время с помощью moment.js.
Видимо, я не могу понять, как правильно использовать setInterval.
Если возможно, я бы предпочел не использовать jQuery, так как moment.js не нужен.
Вот что у меня есть: http://jsfiddle.net/37fLF/2/.
$(document).ready(function () {
var datetime = $('#datetime'),
date = moment(new Date()),
update = function(){
datetime.html(date.format('dddd, MMMM Do YYYY, h:mm:ss a'));
};
update();
setInterval(update, 1000);
});
4 ответа
Я сделал несколько изменений в вашем коде:
Обратите внимание, что метод обновления теперь находится за пределами ready
обработчик события
код:
var datetime = null,
date = null;
var update = function () {
date = moment(new Date())
datetime.html(date.format('dddd, MMMM Do YYYY, h:mm:ss a'));
};
$(document).ready(function(){
datetime = $('#datetime')
update();
setInterval(update, 1000);
});
рабочая демоверсия: jsfiddle
Положил
date = moment(new Date());
внутри функции обновления. Теперь вы просто печатаете одну и ту же дату каждую секунду;)
Еще раз спасибо за ваши ответы. Код, с которым я закончил, следует. (Обратите внимание на датский i18n)
moment.lang('da');
var datetime = null, date = null;
var datetime_update = function() {
date = moment(new Date());
datetime.html(date.format('[Lige nu: ] dddd [d.] Do MMMM YYYY [kl.] HH:mm:ss'));
};
$(document).ready(function() {
datetime = $('#datetime');
datetime_update();
setInterval(datetime_update, 1000);
});
РЕДАКТИРОВАТЬ: Здесь через девять месяцев после того, как я задал этот вопрос, я понял, как сделать это без jQuery (как я изначально просил). Вот:
function date_time() {
now = moment().format('dddd [d.] Do MMMM YYYY [kl.] HH:mm:ss');
document.getElementById('timer').innerHTML = now;
setTimeout(function () { date_time(); }, 1000);
}
date_time();
И затем, конечно, используйте его с идентификатором HTML, например:
<span id="timer"></span>
Вот как это происходит у меня и работает, вы можете проверить это здесь
HTML
JavaScript
< script language="javascript" type="text/javascript">
function date_time()
{
var dt = new Date();
document.getElementById('<%=Label1.ClientID%>').innerHTML = dt;
setTimeout(function () { date_time(); }, 1000);
}
date_time();
< /script>