首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Javascript倒计时使用服务器端时间来完成

Javascript倒计时使用服务器端时间来完成
EN

Stack Overflow用户
提问于 2014-07-04 00:15:11
回答 2查看 911关注 0票数 0

我正在使用这个脚本来倒计时,它是有效的。

代码语言:javascript
复制
            <script type="text/javascript">

        (function (e) {
        e.fn.countdown = function (t, n) {
        function i() {
        eventDate = Date.parse(r.date) / 1e3;
        currentDate = Math.floor(e.now() / 1e3);
        if (eventDate <= currentDate) {
        n.call(this);
        clearInterval(interval)
        }
        seconds = eventDate - currentDate;
        days = Math.floor(seconds / 86400);
        seconds -= days * 60 * 60 * 24;
        hours = Math.floor(seconds / 3600);
        seconds -= hours * 60 * 60;
        minutes = Math.floor(seconds / 60);
        seconds -= minutes * 60;
        days == 1 ? thisEl.find(".timeRefDays").text("day") : thisEl.find(".timeRefDays").text("day");
        hours == 1 ? thisEl.find(".timeRefHours").text("hours") : thisEl.find(".timeRefHours").text("hours");
        minutes == 1 ? thisEl.find(".timeRefMinutes").text("Minutes") : thisEl.find(".timeRefMinutes").text("Minutes");
        seconds == 1 ? thisEl.find(".timeRefSeconds").text("Seconds") : thisEl.find(".timeRefSeconds").text("Seconds");
        if (r["format"] == "on") {
        days = String(days).length >= 2 ? days : "0" + days;
        hours = String(hours).length >= 2 ? hours : "0" + hours;
        minutes = String(minutes).length >= 2 ? minutes : "0" + minutes;
        seconds = String(seconds).length >= 2 ? seconds : "0" + seconds
        }
        if (!isNaN(eventDate)) {
        thisEl.find(".days").text(days);
        thisEl.find(".hours").text(hours);
        thisEl.find(".minutes").text(minutes);
        thisEl.find(".seconds").text(seconds)
        } else {
        alert("Invalid date. Example: 30 Tuesday 2013 15:50:00");
        clearInterval(interval)
        }
        }
        thisEl = e(this);
        var r = {
        date: null,
        format: null
        };
        t && e.extend(r, t);
        i();
        interval = setInterval(i, 1e3)
        }
        })(jQuery);
        $(document).ready(function () {
        function e() {
        var e = new Date;
        e.setDate(e.getDate() + 60);
        dd = e.getDate();
        mm = e.getMonth() + 1;
        y = e.getFullYear();
        futureFormattedDate = mm + "/" + dd + "/" + y;
        return futureFormattedDate
        }
        $("#countdown").countdown({
        date: "<?php echo $newcounter ?> ", // Change this to your desired date to countdown to
        format: "on"
        });
        });

        </script> 

此脚本使用我的客户端日期,但我希望使用我的服务器日期。如何读取从我的服务器读取的数据?我在我的脚本中尝试了以下代码:

代码语言:javascript
复制
currentDate = <?php echo time() ?>;

但是我的倒计时停止了,不工作了。

EN

回答 2

Stack Overflow用户

发布于 2014-07-04 00:26:32

代码语言:javascript
复制
<?php
    date_default_timezone_set('Europe/Vienna');
    $now = new DateTime();
    $dateJsFormat = $now->format('Y') .',' . ($now->format('m')-1) .','.$now->format('d') .',' . $now->format('H') .','.$now->format('i');
?>

<script>


  var date = new Date(<?= $dateJsFormat ?>);
  alert(date);

</script>

JS-Date对象需要以下格式作为参数:

代码语言:javascript
复制
new Date(Year, Month, day, hour, minute) // JS-Code

月份必须减去1:

代码语言:javascript
复制
$now->format('m')-1 // see php-code above

在您的示例中,您必须设置以下内容:

代码语言:javascript
复制
$("#countdown").countdown({
    date: "<?= dateJsFormat ?>", // Change this to your desired date to countdown to
    format: "on"
});

希望这能有所帮助。

票数 0
EN

Stack Overflow用户

发布于 2014-07-04 00:26:48

您有服务器时间。您这样做是正确的--不需要使用AJAX。我认为您的问题涉及传递给倒计时函数的日期的格式。倒计时似乎需要一个数字(newcounter =等待的数字毫秒?),但您传递的是时间戳(<?php echo time() ?>)。

请参阅上面的@APAD1注释。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24558765

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档