setTimeout()的用法就不赘述了。
setTimeout(code,millisec);
最近遇到的困惑是,code加引号和不加引号的区别。
结论:
第一个参数可以是字符串, 也可以是函数
如果是字符串,则当作 javascript 语句执行,,执行的环境是全局,不捕捉局部变量。
<span style="font-size:18px;">var f1 = function() {
alert(aaaa);
};
window.onload = function() {
var f1 = function() {
alert(bbbb);
};
//setTimeout("f1()",3000);//aaaa 全局变量
setTimeout("f1",3000);//无动作,居然不会报错,但这种写法明显是错误的
//setTimeout(f1,3000);//bbbb 若注释掉局部的f1,则执行全局f1</span>
<span style="font-size:18px;"> //等同于</span><span style="font-size: 18px; font-family: arial, 宋体, sans-serif, 'Microsoft YaHei', tahoma;">setTimeout(</span><span style="font-family: arial, 宋体, sans-serif, 'Microsoft YaHei', tahoma; font-size: 18px;">function() {alert(bbbb);}</span><span style="font-size: 18px; font-family: arial, 宋体, sans-serif, 'Microsoft YaHei', tahoma;">,3000)<span style="white-space:pre"> </span>这样一看就好理解了</span><span style="font-size:18px;">
//setTimeout(f1(),3000);//bbbb但计时失效,直接执行局部的f1
};</span>
另外,函数加括弧和不加括弧的区别是一个是数据(函数可以作为数据传递),一个是函数调用(运行函数) --部分引用hzrui的说法