function makeProperty(o, name) { var value; o["get" + name] = function() { return value; }; o["set" + name] = function(v) { value = v; }; } var o = {}; makeProperty(o, "Name"); o.setName("Frank"); alert(o.getName()); (function(o) { alert(1); for(a in o) { alert(a + " = " + o[a]); } })(o); 这段代码中的那个对象的value值在那里存放着,写的测试代码并没有输出出来,但是用o.getName(),却可以得到!帮忙解答一下,不胜感激。
2 回答
芜湖不芜
TA贡献1796条经验 获得超7个赞
js中 某个函数的内部函数在该函数执行结束后仍然可以访问这个函数中定义的变量,这称为闭包(Closure)
function outside()
{
var myVar = 1;
return function (){
alert(myVar);
}
}
var t = outside();
t();
js中 某个函数的内部函数在该函数执行结束后仍然可以访问这个函数中定义的变量,这称为闭包(Closure)
下面例子是给三个锚anchor1,anchor2,anchor3添加onclick事件,可以预期的效果是点击锚点显示相应的锚点ID,实际上却都是显示"My id is anchor4", 这个就是闭包作用引起的逻辑上的bug,添加事件的函数执行完后i的值为4,
ADS.addEvent(window, 'load', function(W3CEvent) {m
for (var i=1 ; i<=3 ; i++ ) {
var anchor = document.getElementById('anchor' + i);
ADS.addEvent(anchor,'click',function() {
alert('My id is anchor' + i);
});
}
});
添加回答
举报
0/150
提交
取消