为了账号安全,请及时绑定邮箱和手机立即绑定

为什么使用o.getName(),却可以得到?

为什么使用o.getName(),却可以得到?

函数式编程 2023-04-09 13:09:59
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);   

});   

}   

});   


查看完整回答
反对 回复 2023-04-12
?
jeck猫

TA贡献1909条经验 获得超7个赞

alert(a + " = " + o[a]); 只是输出方法定义啊 
alert(a + " = " + o[a]());才是方法调用

查看完整回答
反对 回复 2023-04-12
  • 2 回答
  • 0 关注
  • 137 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信