今天写了个网页想要在jquery里用settimeout延时调用另一个函数,但是死活都调不到,程序大概结构是这样:
$(function(){
function a(){
}
function b(){
settimout("a()",1000);
}
}
调出错误控制台检查后发现是 a not defined(找不到a这个函数
查了资料之后我才知道,settimeout的作用机制其实是把函数加入到全局(window)的空间里的任务队列,在全局的命名空间里是找不到匿名函数里定义的函数的,自然也就无法调用了
要修正这个错误可以有两种解决办法:
一是把function a()移到外面全局的空间里去,这样settimeout在执行的时候就可以找到它
function a(){
}
$(function(){
function b(){
settimout("a()",1000);
}
}
二是直接用函数的名字a而不是"a()",这样相当于把直接把函数加入到任务队列中而不是在任务队列中调用这个函数
$(function(){
function a(){
}
function b(){
settimout(a,1000);
}
}
当然,肯定是第二种方法来得优雅又简单了。
PS:在查资料的时候,还发现一个settimeout的特点或者说是javascript的特点,那就是javascript是单线程的,例如用settimeout写个1秒后的死循环那么1秒之后的settimeout队列里的函数都不会被执行(至于整个程序会不会都卡住有待测试