首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >javascript setTimeout没有做我期望的事情。

javascript setTimeout没有做我期望的事情。
EN

Stack Overflow用户
提问于 2012-02-29 16:40:57
回答 6查看 97关注 0票数 1
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function myfunction()
  {
  window.setTimeout(alert('I waited for you.'),700000000);
  }

当我调用这样的函数时,我会立即收到一个警告,说“我一直在等你”。

我最初将7000作为第二个参数,但不断将其推高,以防它是秒以外的东西。我显然想让这个函数做一些其他的事情,但是我把它分解成这个简单的例子来证明问题所在。

我的错误是什么?

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2012-02-29 16:43:36

你必须传递一个函数引用,而不是像这样执行alert()的结果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function myfunction() {
    window.setTimeout(function() {alert('I waited for you.')},700000000);
}

当您将alert('I waited for you.')传递给setTimeout()时,您是在告诉javascript解释器执行alert('I waited for you.'),然后将返回结果传递给setTimeout()。因为它会立即执行alert()语句,而alert不会返回一个函数供setTimeout()使用,所以这显然不是您想要的。

相反,您希望将函数引用传递给setTimeout()。这可以通过我上面提供的例子中的匿名函数来完成,也可以通过一个单独的命名函数来完成,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function myAlert() {
    alert('I waited for you.');
}

function myfunction() {
    window.setTimeout(myAlert, 700000000);
}

注意:对于更高级的用法,您实际上可以将立即执行的函数传递给setTimeout(),只要该函数返回setTimeout()稍后可以调用的函数引用。但是,这显然不是您在这里尝试使用alert()的用法

票数 3
EN

Stack Overflow用户

发布于 2012-02-29 16:43:31

尝尝这个

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function myfunction() {
  window.setTimeout( function(){alert('I waited for you.');}, 700000000);
}

在您的代码中,函数alert被立即调用。如果您想在以后执行,则应该将对函数的引用传递给setTimeout,而不是对函数的调用。

票数 2
EN

Stack Overflow用户

发布于 2012-02-29 16:43:54

你应该这样做

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function makeAlert(){
  alert('I waited for you.')
}

window.setTimeout(makeAlert,700000000);

否则会立即执行alert()

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9503070

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文