前言
在使用setInterval时发现先等待再执行,我傻傻地再写了一个初始化function。幸好今日突发奇想来查一查,以致于以后不再接着蠢下去。
解决方法
在使用setInterval(function,delayTime)方法时,发现它会为函数的第一次调用也做延迟。一般我们都是第一次立即调用,然后延迟调用。我的解决方法如下:
需要延迟调用的函数:
function callinSound(){
var callin=$('#callin')[0];
callin.load();
callin.play();
//第一次执行完成后返回这个函数
return callinSound;
}
调用方:setInterval(callinSound(),6000);
首先,调用callinSound()方法,然后延迟执行。
科普一下:
js中函数参数如果是”函数名+()“,则会先执行函数,然后将返回值作为真正的参数。
相反参数没加“()”则会被作为一个函数块指针,不先执行。
在这里我们就可以利用这一特点实现所需要的效果。
---------------------
作者:南京大学软工研究生
来源:CSDN
原文:https://blog.csdn.net/qq_29012499/article/details/89489115
版权声明:本文为博主原创文章,转载请附上博文链接!