- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我试图在倒计时达到 0 时更新日期,而无需刷新浏览器。
这是代码
var tdy = new Date();
var nxt = new Date();
var dd = new Date();
tdy.setHours(16,00,0,0);
nxt.setHours(16,00,0,0);
var month = new Array();
month[0] = "Jan";
month[1] = "Feb";
month[2] = "Mar";
month[3] = "Apr";
month[4] = "May";
month[5] = "Jun";
month[6] = "Jul";
month[7] = "Aug";
month[8] = "Sep";
month[9] = "Oct";
month[10] = "Nov";
month[11] = "Dec";
var mth = month[dd.getMonth()];
function doCountDown() {
if(tdy <= nxt){
nxt.setDate(nxt.getDate()+1);
dd.setDate(dd.getDate()+3);
if(dd.getHours() == 16){
dd.setDate(dd.getDate()+1);
}
}
$('#clock').countdown(nxt).on('update.countdown', function(event){
$('#delivered-date').text(dd.getDate()+' '+mth+' '+dd.getFullYear());
$(this).text(event.strftime('%H hr %M min %S sec'));
})
.on('finish.countdown', function(event){
setTimeout(doCountDown, 1000);
});
}
$(document).ready(function () {
doCountDown();
});
这是 jsfiddle,http://jsfiddle.net/2dot1geo/1/
要测试日期是否已更新,只需将 dd.getHours 更改为 dd.getMinutes 并更改 var tdy 和 var nxt 的 2 个 setHours。
我已经使用“分钟”进行了测试,看看日期是否在不刷新浏览器的情况下更新,但事实并非如此。
只有刷新浏览器后,日期才会更新。
那么我该如何改变它才能工作呢?我需要在倒计时达到 0 或达到我想要的时间时更新日期。没有浏览器刷新。
仅供引用,如果倒计时达到 0 或达到 1600(下午 4 点),如果小时等于 16,则日期将+1。因此,当到达下午 4 点时,日期应增加 1 天,而无需刷新浏览器。
最佳答案
我终于自己解决了这个问题。请随意引用此供您自己使用。
这是我自己的答案。
Javascript:
function spellMonth(mth){
var month = new Array();
month[0] = "Jan";
month[1] = "Feb";
month[2] = "Mar";
month[3] = "Apr";
month[4] = "May";
month[5] = "Jun";
month[6] = "Jul";
month[7] = "Aug";
month[8] = "Sep";
month[9] = "Oct";
month[10] = "Nov";
month[11] = "Dec";
var m = month[mth];
return m;
}
function doCountDown(){
var nxt = new Date();
nxt.setHours(nxt.getHours()<16?16:40,00,0,0);
//nxt.setHours(21,57,0,0);
var dd = new Date();
dd.setDate(dd.getDate()+2);
if(dd.getHours()>=nxt.getHours()){
//if(dd.getMinutes()>=nxt.getMinutes()){
dd.setDate(dd.getDate()+1);
}
else{
dd.setDate(dd.getDate());
}
$('#date').html(dd.getDate()+' '+spellMonth(dd.getMonth())+' '+dd.getFullYear());
return nxt;
}
$('#clock').countdown(doCountDown()).on('update.countdown', function(event){
$(this).html(event.strftime('%H hr %M min %S sec'));
})
.on('finish.countdown', function(event){
$(this).html(event.strftime('%H hr %M min %S sec'));
$(this).countdown(doCountDown(), function(event){
$(this).html(event.strftime('%H hr %M min %S sec'));
});
});
HTML:
<div id="clock"></div>
<div id="date"></div>
JSFiddle - http://jsfiddle.net/archampion/s4q1orwr/2/
正如您所看到的,代码有些相似。但我没有将倒计时放入 doCountDown 函数中,而是返回 doCountDown 作为日期和时间,并将其作为倒计时。
在 doCountDown() 中,我创建了一个新日期 nxt,以检查今天的时间是否小于 16 点(即下午 4 点),时间设置为 16,否则设置为 40(即第二天下午 4 点,16 点 + 24 小时 = 40 小时)。由于我想倒计时 24 小时,这就是我的计算方式,因此我返回 nxt 作为倒计时。
此外,我想向人们展示一个约会。最初,日期将显示今天的日期+2。然后我对照 nxt 的时间检查该日期的时间(这是今天的时间)。如果 date 的小时数大于或等于 nxt 的小时数(设置为 1600 小时),我会再添加一天,否则保持不变。
供您引用,我使用的 jquery 倒计时来自 http://hilios.github.io/jQuery.countdown/
所以你看到了这一行,
$(this).html(event.strftime('%H hr %M min %S sec'));
同时存在于 update.countdown 和 finish.countdown 中。
如果你只是将其放在 update.countdown 上,计时器将在 1 秒处停止,然后重新开始倒计时。这有点奇怪,可能看起来不正确,因为通常人们会在倒计时中看到全零。所以你也必须把它放在 finish.countdown 上。这是为了告诉计时器倒计时何时完成,将倒计时更新为零,然后重新开始倒计时。
任何人有任何疑问,请随时询问。
关于javascript - 如何在倒计时达到 0 时更新日期而不刷新浏览器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27895490/
为什么不倒计时? var container = document.getElementById('dl'); var seconds = 10; var timer; function count
我已经在网上搜索过,但所有现成的网站都是您指定日期的地方,它会倒计时到该日期。我需要的是可以简单地从“27 分 43 秒”(以这种格式)倒计时到 0,从他们登陆页面时开始,有人有可用的片段吗? 最佳答
我正在使用this plugin进行倒计时。在他的例子中,他正在倒计时澳大利亚国庆日 $(function () { var countdownDate = new Date(); count
所以我是 Perl 的新手,我发现我想编写一个倒计时代码,并且真的很挣扎,我在这里找到了一些代码 http://www.perlmonks.org/bare/?node_id=407922并试图弄清楚
我正在尝试创建倒计时。基本上我有客户下订单的时间(以日期时间格式存储在数据库中,例如“2014-08-14 12:52:09”),我也有完成订单所需的时间(其中要么是小时和分钟“1”45”,要么只是分
我正在使用 Flask 构建一个游戏,其中每一轮都有倒计时时间来完成这一轮。我希望时间值每秒减少 1 并在不重新加载页面的情况下进行更新。倒计时本身使用 time.sleep 等待 1 秒,然后将生成
您将获得一个名为 start_num 的整数。编写一段代码,从start_num开始倒计时到1,倒计时结束后,打印出“Liftoff!”。 我不确定如何执行此操作并一直陷入困境。 这是我在问题开始时提
我想为我的 Android 程序实现一个 java 倒计时器,但我不知道该怎么做。它应该从 60 到 0 计算时间,最后程序应该结束,但用户需要查看还剩多少时间,因此计时器应该始终可见。我设法实现了一
我正在使用 jquery_countdown (http://keith-wood.name/countdown.html) 设置 60 分钟计时器。我知道我可以在时间到期时运行回调函数,但是有没有办
所以我在这个网站上找到了这段代码,但我想更改它的一件事,但我似乎无法弄清楚,所以我需要一些帮助。我想要做的是删除日期中的年份,以便倒计时对应于它所在的年份。 var end = new Date('
所以,我有以下(秒倒计时)井然有序。但!我也尝试在倒计时中添加小时和分钟。理想情况下保持相同的结构,并且只使用纯 JS。我希望输出是: 本次促销事件还剩 X 小时、X 分钟和 X 秒! var cou
最近我正在做电子图书馆的项目,需要为用户阅读的每本书提供倒计时器。 例如,在我的数据库中,“用户”有“100 秒”的信用时间来阅读这本书,并且只有当他们阅读这本书时,时间才会减少。 这是我的代码: g
我有一个倒计时脚本,可以获取实时时间并将其从设定时间中减去。除了除非您刷新页面否则它不会更新这一事实之外,这一切都有效。我的函数底部的 setInterval 指示函数每隔一秒运行一次,但它似乎没有这
在已经运行了几次代码之后,我想再次运行我的代码(倒计时)。 Javascript: var btn1 = document.getElementById('btn1'); function timer
如何让这个倒计时在刷新时不重置倒计时?就像当我单击刷新时它应该继续倒计时而不是再次重置倒计时,从“14d、22h、23m、32s”(刷新)继续到“14d、22、59m、59s”。 通过一些研究我发现我
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
我是 python 的新手,正在尝试运行一个函数,该函数将在给定一个变量的情况下倒计时到零,然后倒计时到原始变量。输出应如下所示: >>> functionname(5) 5, 4, 3, 2, 1,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 6 年前。
我的目标很简单: 在我的 xml 文件中,我有一个名为:textView2 的 TextView 。 我需要的是一个倒计时,从 15 倒计时到 0,每过一秒,textview 就会更新(例如:15,1
我想要完成的是实时更新的倒计时...像这样: 6 天(只是几天) 12 小时(1 天内的几个小时) 59 分钟(1 小时内仅几分钟) 59 秒(1 分钟内的几秒) 实现此目的的最佳方法? 最佳答案 您
我是一名优秀的程序员,十分优秀!