JS数据驱动的定时器开关(可暂停)

JavaScript010

JS数据驱动的定时器开关(可暂停),第1张

原本我们若想将一个定时器暂停或清除,我们通常会用clearInterval()的方法。我们在setInterval时存储这个Interval的id,之后再需要暂停时通过id查找并清除该定时器(甚至需要记录请出时变化的数据),等到需要定时器继续运转我们就setInterval()在创建一次。

本次在大量使用定时器的过程中,为了优化繁琐的操作,我给定时器内部回调函数添加了数据驱动, 每个操作对应 一个常驻定时器 只在页面初始化时创建一次定时器,后续不再重新创建或释放

接下来我会举几个本次做的例子:

如果我们用传统释放定时器的方式,那么释放时我们还需记录运行时间,当前状态等。重新创建我们还需要把记录的值传递进去,不甚繁琐。

以上两个例子就是本次思想的精髓, 之后准备二次封装一个新的定时器,敬请期待

做完了: 数据驱动二次封装定时器工具类

球球你们看完点个赞吧。

var cont=0

function change(num)

{

var change1=document.getElementById("changes")

change1.innerHTML="<img src='img/huandengpian_"+num+".jpg'/>"

document.getElementById("cg"+num).style.backgroundColor="#CC0000"

document.getElementById("cga"+num).style.color="#FFFFFF"

document.getElementById("cga"+num).style.fontWeight="bolder"

}

function changee(num)

{document.getElementById("cg"+num).style.backgroundColor="#FFFFFF"

document.getElementById("cga"+num).style.color="#555555"

document.getElementById("cga"+num).style.fontWeight="normal"

}

setInterval(aa,5000)每5秒执行一次

function aa()

{

cont++

if(cont<7)

changee(cont)

change(cont)

}else

cont=0

}

</script>

你那好像缺少了<div id="changes"></div>这个层的定义