6

目前我们有这个代码,它可以工作,除了它需要使用指定的时区,而不是用户的时区:

 $('#countdown').countdown('<?php echo $date_end?>').on('update.countdown', function(event) {
            var format = '%-S second%!S';

            if (event.offset.years > 0 || event.offset.weeks > 0 || event.offset.days > 0 || event.offset.hours > 0 || event.offset.minutes > 0) {

                if(event.offset.minutes > 0) {
                    format = '%-M minute%!M ' + format;
                }
                if(event.offset.hours > 0) {
                    format = '%-H hour%!H ' + format;
                }
                if(event.offset.days > 0) {
                    format = '%-d day%!d ' + format;
                }
                if(event.offset.weeks > 0) {
                    format = '%-w week%!w ' + format;
                }
            }
           $(this).html(event.strftime(format));
        }).on('finish.countdown', function(event) {
           $(this).html('Finished');
        });

我见过几个添加时区的例子,但没有一个像我们一样使用 jquery 倒计时插件。

关于如何将 +10 添加为当前时区的任何想法?所以它使用它而不是用户的时区?

谢谢。

4

3 回答 3

5

我猜你正在使用https://github.com/hilios/jQuery.countdown,因为它没有使用它的时区选项。

我使用 moment.js 和 moment-timezone-with-data.js(包含所有时区)来处理时区。

<div data-countdown="2015/05/20"  data-zone="US/Central" class="countdown"></div>

函数将日期转换为适当的时区并以毫秒为单位返回

var timefun = function (countdown,zone){
 var date = moment.tz(countdown,"YYYY/MM/DD",zone);
 return date.valueOf();   
}

利用上述函数将毫秒作为参数传递给 jQuery.countdown()

$(".countdown").countdown(timefun($(".countdown").data("countdown"),$(".countdown").data("zone")))

示例:http: //jsfiddle.net/heLrsnqx/2/

如果您使用的是http://keith-wood.name/countdown.html,请参考以下示例

示例:http: //jsfiddle.net/w1oyv8kv/

于 2015-05-17T21:45:11.133 回答
4

看起来代码中使用的实际日期来自该 PHP 片段。您可以使用以下方法在 PHP 中设置默认时区:

date_default_timezone_set($timezone_identifier);

$timezone_identifier是一个字符串,可以是'UTC'or之类的东西'America/Los_Angeles'

有关支持的时区标识符的完整列表,请参阅相关的 PHP 文档

于 2015-05-13T03:25:43.850 回答
1

根据文档,您可以使用event.finalDate. 因此,如果您无法设置时区服务器端,请event.finalDate.setUTCHours(10)在调用之前执行event.strftime

更多关于 setUTCHours 的信息:https ://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date/setUTCHours

于 2015-05-13T03:36:52.540 回答