0

Web ページに現在の日付と時刻を表示するスクリプトがあります。

<script type = "text/javascript">

function startTime() {
var now = new Date();
var h=now.getHours();
var min=now.getMinutes();
var s=now.getSeconds();
var ampm=(now.getHours()>11)?"PM":"AM";
var d=now.getDay();
var y=now.getFullYear();
var mon=now.getMonth();
var da=now.getDate();
var endings=["st","nd","rd","th"];
var dayendings=[0,1,2,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,4,0,2,3,4,4,4,4,4,4,1];
var days=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday"];
var months=["January","February","March","April", "May", "June","July","August","September", "October", "Novemeber","Decemeber"];
if (h>12) {h-=12}
if (h==0) {h=12};
if (min<10) {min="0"+min}
if (s<10) {s="0"+s}
da+=endings[dayendings[da]];
if (da<10) {da="0"+da};
d=days[d];
mon=months[mon-1];
document.getElementById("time").innerHTML=d+", "+mon+" "+da+", "+y+" "+h+":"+min+":"+s+" "+ampm;
var tim = setTimeout("startTime()",1000);
}

</script>

しかし、結果は次のようになります。

Friday, April NaN, 2012 6:37:36 PM

どうすれば正しく作れApril NaN, 2012ますか?今日の日付に違いないMay 25,2012

4

5 に答える 5

4

せめて自分が変わるべき

da+=endings[dayendings[da]];

da+=endings[dayendings[da - 1]];

現在、オフバイワンのバグがあるためです (daは 1 から 31 ですが、上のインデックスdayendingsは 0 から 30 です)。

「今日」が月の 31 日である場合、これで問題はすぐに修正されます。

dayendingsの値も4意味がないため、修正が必要です。

余談ですが、このコードはもっと良いものにする必要があります。こんな方がいいんじゃない?

function startTime() {
    document.getElementById("time").innerHTML =
        moment().format("dddd, MMMM Do, YYYY h:mm:ss A");
}
于 2012-05-25T10:44:41.470 に答える
2

あなたvar dayendings=[0,1,2,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,4,0,2,3,4,4,4,4,4,4,1];にはいくつかの4値が含まれています。ただし、var endings=["st","nd","rd","th"];は 4 の長さしかないため、 にアクセスすると undefined が返されますendings[4]

daまた、 が からの範囲131あり、配列のインデックス化されていないため、off-by-one エラーが発生する場合がありますdayendings

于 2012-05-25T10:47:44.437 に答える
0

最初にこの関数を生成し、.js ファイルとして保存します

function date_time(id) {
    date = new Date;
    year = date.getFullYear();
    month = date.getMonth();
    months = new Array('January', 'February', 'March', 'April', 'May', 'June', 'Jully', 'August', 'September', 'October', 'November', 'December');
    d = date.getDate();
    day = date.getDay();
    days = new Array('Sunday', 'Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday');
    h = date.getHours();
    if (h < 10) {
        h = "0" + h;
    }
    m = date.getMinutes();
    if (m < 10) {
        m = "0" + m;
    }
    s = date.getSeconds();
    if (s < 10) {
        s = "0" + s;
    }
    result = '' + days[day] + ' ' + months[month] + ' ' + d + ' ' + year + ' ' + h + ':' + m + ':' + s;
    document.getElementById(id).innerHTML = result;
    setTimeout('date_time("' + id + '");', '1000');
    return true;
}

次に、HTMLページでこのコードを使用して、現在の時刻と日付を表示します

<script type="text/javascript"> window.onload = date_time('date_time'); </script>

ページの head 部分にある script タグを忘れないでください: ex

于 2013-05-22T10:27:17.713 に答える
0

カウンターのロジックが正しくないようです。次のコードを試してください。

function makeArray() {
for (i = 0; i<makeArray.arguments.length; i++)
this[i + 1] = makeArray.arguments[i];
}
var now = new Date();
var h=now.getHours();
var min=now.getMinutes();
var s=now.getSeconds();
var ampm=(now.getHours()>11)?"PM":"AM";
var months = new makeArray('January','February','March','April','May',
'June','July','August','September','October','November','December');
var date = new Date(); 
var day = date.getDate();
var month = date.getMonth() + 1;
var yy = date.getYear();
var year = (yy < 1000) ? yy + 1900 : yy;
var endings=["st","nd","rd","th"];
var dayendings=[0,1,2,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,3,4,0,2,3,4,4,4,4,4,4,1];
var days=["Sunday","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"];

document.write(days[date.getDay()] + " " + months[month]+ " " + day + ", " + year + " " + h + ":" + min + ":" + s + " " + ampm);
于 2012-05-25T11:14:57.040 に答える
0

この jsfiddleには比較的単純な DateTime オブジェクトがあります。役に立つかもしれませんか?あなたの場合、このオブジェクトを使用すると、このコマンドは必要な形式で日付を表示します (PM/AM 時間形式とは別に)

XDate({date:new Date,lang:'EN'}).format('WD, MM dd, yyyy, hh:mm:se0');
//=> Friday, May 25 2012, 13:05:03 
于 2012-05-25T11:24:42.440 に答える