setInterval 回调函数传参数

您所在的位置:网站首页 函数定义时不能带参数怎么办 setInterval 回调函数传参数

setInterval 回调函数传参数

2024-07-13 09:53| 来源: 网络整理| 查看: 265

关于setInterval方法的详细用法可以参阅JavaScript setInterval()一章节。

其实在上述文章也涉及到为回调函数传参数,不过很多朋友关注点在传参本身。

下面就通过代码实例介绍一下如何为回调函数传参数。

一.错误传参方式举例:

下面看一个比较常见的错误传参方式,代码实例如下:

 

[JavaScript] 纯文本查看 复制代码运行代码

1

2

3

4

function func(){

  console.log("http://www.softwhy.com");

}

setInterval(func,5000);

代码会在5秒后打印出蚂蚁部落网址"http://www.softwhy.com"。

下面我们想让func函数更加灵活一些,将打印内容通过参数的方式传递。

代码实例如下:

 

[JavaScript] 纯文本查看 复制代码运行代码

1

2

3

4

function func(url){

  console.log(url);

}

setInterval(func("http://www.softwhy.com"),5000);

上述代码的本意是为回调函数传递参数"http://www.softwhy.com",然后在5秒后打印出参数。

但是运行后发现,参数会被立即打印出来,这是因为func并不是setInterval的回调函数,因为func会立即执行(也就是网址会被立即打印的原因),实际传递给setInterval的是func的返回值(当然它的返回值为undefined)。

二.传参正确方式:

setInterval还可以传递第三个参数,此参数被作为回调函数的参数。

代码实例如下:

 

[JavaScript] 纯文本查看 复制代码运行代码

1

2

3

4

function func(url){

  console.log(url);

}

setInterval(func,5000,"http://www.softwhy.com");

上述代码会在5秒后打印出本站网址。

由于IE9和IE9以下浏览器不支持第三个参数,所以较早的教程很少教程。

上面的方式当前还不够稳妥,要兼容当前所有主流浏览器,可以采用如下方式。

 

[JavaScript] 纯文本查看 复制代码运行代码

1

2

3

4

5

setInterval((function(){

  return function(){

    console.log(url);

  }

})("http://www.softwhy.com"),5000);

上述代码可以在5秒后打印出本站网址。

代码分析如下:

(1).setInterval第一个参数是一个立即执行匿名函数,为其传递的参数是要打印的网址。

(2).此匿名函数执行后返回一个函数,返回的函数才是真正传递给setInterval的回调函数。

(3).根据作用域与作用域链的原理,返回的函数可以使用通过外层函数传递进来的参数url。

(4).于是可以正常打印出传递的网址。

总结:如果不太考虑浏览器兼容问题,可以使用为setInterval传递第三个参数的方式,如果要稳妥,那么推荐使用最后一种方式,特别说明,对于settimeout方法也是如此。



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3