setTimeout(“alert(‘a’)”,3000); setTimeout(function(){alert(“a”)},3000);这两种有什么区别?
1个回答
推荐于2018-03-19
展开全部
两者区别:
1.作用域问题:
前者作用域是全局作用域,如果前者调用的是局部作用域的函数,会出现找不到函数的错误
如:
function bar() {
function foo() {
alert('b');
}
setTimeout('foo()', 1000);
}
bar();
会出现错误foo is not defined的错误。
后者则会先寻找局部作用域,如果发现此函数则执行,否则到全局作用域去寻找,最后找不到才会出现foo is not defined。
2.效率问题:
前者使用了隐藏的eval执行传进去的字符串”alert(’a')“,效率有所降低
后者则是直接调用函数
3.安全问题
前者的安全问题是由eval引起的,如:
var foo = 1;
function test() {
var foo = 2;
var bar = eval;
bar('foo = 3');
return foo;
}
test(); // 2
foo; // 3
后者不存在此问题
1.作用域问题:
前者作用域是全局作用域,如果前者调用的是局部作用域的函数,会出现找不到函数的错误
如:
function bar() {
function foo() {
alert('b');
}
setTimeout('foo()', 1000);
}
bar();
会出现错误foo is not defined的错误。
后者则会先寻找局部作用域,如果发现此函数则执行,否则到全局作用域去寻找,最后找不到才会出现foo is not defined。
2.效率问题:
前者使用了隐藏的eval执行传进去的字符串”alert(’a')“,效率有所降低
后者则是直接调用函数
3.安全问题
前者的安全问题是由eval引起的,如:
var foo = 1;
function test() {
var foo = 2;
var bar = eval;
bar('foo = 3');
return foo;
}
test(); // 2
foo; // 3
后者不存在此问题
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询