您的位置:首页 > Web前端 > JavaScript

【JavaScript】关于setTimeout()的一点学习

2014-12-19 19:12 465 查看
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的说法
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: