欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

setTimeout第三个参数

程序员文章站 2024-02-01 20:37:34
在廖雪峰大神的官方网站看nodejs的时候,发现自己对Promise函数不甚了解,于是转去看Promise函数,看到了这段代码: setTimeout居然有第三个参数!!! 还有这种操作?我怎么不知道?我怕不是个假的前端。 马上查了MDN,发现确实有第三个参数,而且不仅三个,第三个之后的参数都将作为 ......

在廖雪峰大神的官方网站看nodejs的时候,发现自己对promise函数不甚了解,于是转去看promise函数,看到了这段代码:

function multiply(input) {
    return new promise(function (resolve, reject) {
        log('calculating ' + input + ' x ' + input + '...');
        settimeout(resolve, 500, input * input);
    });
}

settimeout居然有第三个参数!!!

还有这种操作?我怎么不知道?我怕不是个假的前端。

马上查了mdn,发现确实有第三个参数,而且不仅三个,第三个之后的参数都将作为settimeout函数的参数使用。

简单测试了一下:

settimeout(function(){
    console.log(arguments)
},2000,"haha");

确实输出了"haha":

setTimeout第三个参数

同上试了一下setinterval,也可以通过第三个参数传参。

不过这种用法有其局限性,我指的当然是该死的ie,以下是mdn的备注:

setTimeout第三个参数

没想到温故真的能知新,我之前都是在匿名函数内再写个函数来传参的,真蠢。

另外,mdn上有针对ie的兼容代码,这里不再抄录。

https://developer.mozilla.org/zh-cn/docs/web/api/window/settimeout