JS整时整分整点事件

JS并没有为我们提供整点方法,但我们知道,在JS里有setTimeout和setInterval方法,可以在一定延时后执行指定的代码。我们需要自己写一个函数来实现整个事件。

怎么确保函数在整点执行?

使用setTimeout方法和Date函数同步时间。

var myDate = new Date();
var myDateS = myDate.getSeconds()*1000;
var myDateMs = myDate.getMilliseconds();//获取到毫秒以减少误差
setTimeout(function () {
    //函数
},60000-myDateS-myDateMs);

上面的代码可以在下一分钟0s开始执行里面的函数,如果需要整时就用3600000减去当前的时分秒毫秒。

如果需要在每个整点都执行这个函数,你可以递归使用这个方法来让每个整点执行某个函数,但是这样做无疑会消耗许多性能。我们需要将递归范围限制在我们自己的函数范围里

function myFunc() {
    //函数
    setTimeout(function () {
        myFunc();
    },60000);//因为是在0s开始执行,所以60s后又是一个整点
}

结合一下,添加一个报时功能

var myDate = new Date();
var myDateS = myDate.getSeconds();
var myDateMs = 1000-myDate.getMilliseconds();
setTimeout(function () {
    myFunc();
},60000-myDateS-myDateMs);
function myFunc() {
    console.log("整分了!");
    setTimeout(function () {
        myFunc();
    },60000);
}

一个整点报时程序就完成了!
注意:使用alert会暂停定时器。

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值