日期和时间脚本 - 即vs ff

时间:2012-07-16 16:33:34

标签: javascript datetime

我的下面的脚本在ie中工作,但在Firefox中我得到:

Mon, July 16th 2012 //this is ok

NaN:NaN:NaN (UTC +2) //but the time???

...

var weekdaystxt = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"];

function showLocalTime(container, servermode, offsetMinutes, displayversion) {
    if (!document.getElementById || !document.getElementById(container)) return
    this.container = document.getElementById(container)
    this.displayversion = displayversion
    var servertimestring = (servermode == "server-php") ? '<? print date("D, F jS Y H:i:s", time())?>' : (servermode == "server-ssi") ? '<!--#config timefmt="%B %d, %Y %H:%M:%S"--><!--#echo var="DATE_LOCAL" -->' : '<%= Now() %>'
    this.localtime = this.serverdate = new Date(servertimestring)
    this.localtime.setTime(this.serverdate.getTime() + offsetMinutes * 60 * 1000) //add user offset to server time 
    this.updateTime()
    this.updateContainer()
}
showLocalTime.prototype.updateTime = function() {
    var thisobj = this
    this.localtime.setSeconds(this.localtime.getSeconds() + 1)
    setTimeout(function() {
        thisobj.updateTime()
    }, 1000) //update time every second 
}
showLocalTime.prototype.updateContainer = function() {
    var thisobj = this
    if (this.displayversion == "long") this.container.innerHTML = '<? print date("D, F jS Y")?>'
    else {
        var hour = this.localtime.getHours()
        var minutes = this.localtime.getMinutes()
        var seconds = this.localtime.getSeconds()
        var ampm = (hour >= 12) ? "PM" : "AM"
        var dayofweek = weekdaystxt[this.localtime.getDay()]
        this.container.innerHTML = formatField(hour, 1) + ":" + formatField(minutes) + ":" + formatField(seconds) + " (UTC +2)"
    }
    setTimeout(function() {
        thisobj.updateContainer()
    }, 1000) //update container every second 
}

function formatField(num, isHour) {
    if (typeof isHour != "undefined") { //if this is the hour field 
        var hour = (num > 24) ? num - 24 : num
        return (hour == 0) ? 24 : hour
    }
    return (num <= 9) ? "0" + num : num //if this is minute or sec field 
}

2 个答案:

答案 0 :(得分:1)

首先,这是你发布的代码的jsFiddle,所以我们都可以看到发生了什么 -

http://jsfiddle.net/HjDds/

请注意,这是一个有效的版本。问题在于IE和Chrome解析日期的方式不同。无论什么&lt;%Now()%&gt;回来的时候,Chrome不喜欢它,并且在创建新的Date()对象时无法解析。

您需要确保您的服务器正在发送一个日期字符串,其格式将适用于浏览器。

至于我的修复(虽然它似乎不是一个修复,因为你似乎想要服务器时间)是替换&lt;%= Now()%&gt;使用新的Date()在servertimestring字符串中。我还添加了冒号,因为我还有一堆额外的东西。

答案 1 :(得分:0)

无效格式数据:星期一,2012年7月16日17:02:32

Php使用$ _SERVER ['REQUEST_TIME']并乘以1000。

这会:

var servertimestring = (servermode == "server-php") ? '<?php echo $_SERVER['REQUEST_TIME']*1000;?>' : (servermode == "server-ssi") ? '<!--#config timefmt="%B %d, %Y %H:%M:%S"--><!--#echo var="DATE_LOCAL" -->' : '<%= Now() %>';

:)