js 带暂停功能的倒计时插件

带暂停功能的倒计时插件

settimeInterval会让倒计时延迟,因为js是单线程,会出现卡顿现象,本插件使用setTimeout优化倒计时缓慢问题

核心代码如下:

var offset = new Date().getTime() - (startTime + startCount * speed);
startCount++;
var nextTime = speed - offset;
if (nextTime < 0) nextTime = 0;
canvasTime = setTimeout(fixed, nextTime);
var start = 1.5 * Math.PI -  pauseData.increase * count;
ctx.clearRect(0, 0, canvasW, canvasH);
ctx.beginPath();
ctx.strokeStyle = pauseData.color;
ctx.closePath();
ctx.arc(60, 60, 56, start, -0.5 * Math.PI, true);
ctx.lineWidth = 3;
ctx.stroke();
if (pauseData.totalTime > 0) {
    pauseData.totalTime -= speed;
} else {
    pauseData.totalTime = 0;
}

代码地址:https://github.com/wamgwei/timer-countDown


可以加我qq:3585929388,欢迎前端小伙伴一起沟通交流问题。


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值