14

moment.jsを使用して動的な日付と時刻を表示する方法を見つけようとしています。

どうやら setInterval を適切に使用する方法がわかりません。

moment.js はそれを必要としないため、可能であれば jQuery を使用しないことをお勧めします。

これが私がこれまでに持っているものです: 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);
});

編集:この質問をしてから9か月後、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 に答える