// 实现1:回调函数consttask=(timer,fn,callback)=>{constid=setTimeout(()=>{fn()callback()},timer)console.log('id',id)}constmySetInterval=(fn,timeout)=>{task(timeout,fn,()=>{task(timeout,fn,()=>mySetInterval(fn,timeout))})}mySetInterval(()=>{console.log(11111)},1000) //...
setTimeout传入的是两个参数,第一个参数是cb代表的是回调函数callback,第二个代表的是时间,以ms计算 setInterval传入的也是两个参数,第一个参数是cb代表的是回调函数callback,第二个代表的也是时间,以ms计算 区别和注意点 setTimeout含义是定时器,到达一定的时间触发一次,但是setInterval含义是计时器,到达一定时间...
使用setTimeout来模拟setInterval可以提供更多控制,避免setInterval可能导致的问题,如多个间隔重叠。在上面的代码中,customSetInterval函数接受一个函数和执行间隔作为参数。函数repeat被定义来递归调用setTimeout,从而不断重复执行输入的函数。 function betterSetInterval(func, interval) { let timeout; const loop = ()...
function mySetInterval(fn,delay,...args) { let cancel = false; const task = () => { setTimeout(() => { if (!cancel) { fn(...args) task(); } },delay) } task(); return () => { cancel = true };}const a = mySetInterval((a) => { ...
使用setTimeout 来实现setInterval的效果 直接上代码,实现的核心就是在延时的情况下递归的调用自己, 1x=02y=-134functioncountMin( )5{ y=y+16document.displayMin.displayBox.value=y7var timer=setTimeout("countMin( )",60000)8}9functioncountSec( )10{ x = x + 111z =x % 6012document.display...
使用setTimeout实现setInterval 杨老师 03-15 00:22 千锋教育setInterval 的作用是每隔一段指定时间执行一个函数,但是这个执行不是真的到了时间立即执行,它真正的作用是每隔一段时间将事件加入事件队列中去,只有当当前的执行栈为空的时候,才能去从事件队列中取出事件执行。所以可能会出现这样的情况,就是当前执行栈...
为什么要使用setTimeout来实现SetInterval? 我们知道setInterval以一定频率来执行一个函数,但是这样有一个问题,加入执行的这个函数相当耗时,超过了我们给定的周期时间,setInterval还会按照约定的时间来执行下次任务吗? 答案是不会,setInterval会等到当前的任务执行完成后,再立即执行下一次的任务,看个例子 ...
理解 setInterval 与 setTimeout 的工作原理有助于模拟 setInterval 使用 setTimeout 实现。setInterval 实际上是将要执行的函数加入到事件队列中,当当前执行栈为空时,才从事件队列取出并执行函数。这可能在执行栈繁忙时导致多个函数被累积到队列中,而非按间隔时间执行。为克服 setInterval 的此缺点,...
参考实现 思路是使用递归函数,不断地去执行 setTimeout 从而达到 setInterval 的效果 简单实现 function mySetInterval(fn, timeout) { function interval() { fn(); setTimeout(interval, timeout); } setTimeout(interval, timeout); } 还可以加个控制器,控制是否继续执行 function mySetInterval(fn, tim...
针对setInterval 的这个缺点,我们可以使用 setTimeout 递归调用来模拟 setInterval,这样我们就确保了只有一个事件结束了,我们才会触发下一个定时器事件,这样解决了 setInterval 的问题。 参考实现 思路是使用递归函数,不断地去执行 setTimeout 从而达到 setInterval 的效果 ...