14

我试图找出如何使用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

4 回答 4

24

我对您的代码进行了一些修改:

请注意,方法更新现在在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

于 2012-05-14T20:31:32.377 回答
3

再次感谢您的回答。我最终得到的代码如下。(注意丹麦语 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 ID 一起使用,例如:

<span id="timer"></span>
于 2012-05-15T19:25:08.993 回答
2

date = moment(new Date());

在更新函数里面。现在你只是每秒打印相同的日期;)

于 2012-05-14T20:24:53.353 回答
0

这就是我的方式,它的工作方式你可以在这里查看

HTML

<asp:Label ID="Label1" runat="server" Text='' >

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>
于 2014-10-20T13:37:46.717 回答