setTimeout/setInterval的第三个参数?

发布于 2022-09-02 14:41:08 字数 314 浏览 37 评论 0

            setTimeout(function() {
                $('.wrap').addClass('anistart');
            }, 3000,setTimeout(function() {
                $('.wrap').removeClass('anistart');
            }, 10000));
            

这里的第三个参数又传了一个定时器,好像是作为了一个回调函数,但是查阅文档发现第三个参数并非指回调函数,那么为什么能够这样使用?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

天邊彩虹 2022-09-09 14:41:09
setTimeout(func, delay, param1, param2, ...)

第三个参数及以后的参数都可以作为func函数的参数

举个例子:

function a(x, y) {
    console.log(x, y) // 2 3
}


setTimeout(a, 1000, 2, 3)
两人的回忆 2022-09-09 14:41:09

根据文档:https://developer.mozilla.org/en-US/docs/Web/API/WindowTimers/setTimeout

第三个以后的参数是作为第一个func()的参数传进去的。但是你这里的代码没用到。

も星光 2022-09-09 14:41:09

那你需要先理解setTimeout的返回值,你的代码可以分解成如下:

var timeoutID = setTimeout(function() {
    $('.wrap').removeClass('anistart');
}, 10000);

setTimeout(function(id) {
    console.log(id);//这里id就是传入的第三个参数,也是之前那个setTimeout的返回值,可以用来把那个定时器清除
    $('.wrap').addClass('anistart');
}, 3000, timeoutID);
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文