YalongLiu
2011-10-11 17:23
浏览 233
已采纳

JavaScript闭包问题

[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(),确可以得到!帮忙解答一下,不胜感激。

  • 写回答
  • 好问题 提建议
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • long13131462101 2011-10-11 23:51
    已采纳

    [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]

    看这个例子

    已采纳该答案
    评论
    解决 无用
    打赏 举报
  • fei1710 2011-10-11 17:43

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

    评论
    解决 无用
    打赏 举报

相关推荐 更多相似问题