[code="text/javascript"]
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);
[/code]
这段代码中的那个对象的value值在那里存放着,写的测试代码并没有输出出来,但是用o.getName(),确可以得到!帮忙解答一下,不胜感激。
[code="java"]
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);
});
}
});
[/code]
看这个例子
alert(a + " = " + o[a]); 只是输出方法定义啊
alert(a + " = " + oa);才是方法调用