超时调用(setTimeout)和间歇调用(setInterval)有什么区别?

间歇调用

间歇调用:每隔指定时间执行相应的代码,直到被取消或者页面卸载。

var i=0;
var intervalId=null;
function A() {
    i++;
    if(i>=10){
        clearInterval(intervalId)
    }
    console.log(i);
}
intervalId=setInterval(A,1000);

上面的代码每隔1s输出一个i值,当i的值到达10时,利用clearInterval取消它的调用。

超时调用

超时调用:在指定的时间过后执行代码。
上述间歇调用用超时调用来写:

var i=0;
function A() {
    i++;
    if(i<=10){
        console.log(i);
        setTimeout(A,1000);
    }else{
        alert("done")
    }
}
setTimeout(A,1000);

在超时调用的回调函数的内部满足一定条件时,继续调用这个超时调用。

为什么不用setInterval?

在现实应用场景中,常用setTimeout而非setInterval,因为setInterval设置的时间值有可能会比执行回调函数的时间小,这样就会产生上一次间歇调用还没有执行完,下一次间歇调用就启动了,这样下一次间歇调用的代码就放到了队列中。而js引擎中只允许有一份未执行的该回调函数在队列中,所以队列中如果再来一个该函数,则该函数会被抛弃。
setTimeout中的计时器是等回调函数执行完毕才开始计时,所以不会出现上述情况。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值