0

假设我有这个代码

var callbacks = {};
for (var i in mylist){

callbacks[i] = { callback: function(){ myFunction( myList[i].someProperty ); }};

}

上面的代码会导致这样的列表:

myList[0].property = "zero";
myList[1].property = "one";

像这样的结果:

callbacks[0].callback // -> returns myFunction("one"); WRONG!
callbacks[1].callback // -> returns myFunction("one");

有什么我可以做的(for..in循环中并且不改变我在匿名函数内部访问的事实myList[i].someProperty)以确保myList[i].someProperty在循环期间而不是在执行函数时分配的值?

4

1 回答 1

1

您可以key在回调上设置一个属性,然后参考this.key

var myList = {
    foo: {
        someProperty: 'oof'
    },
    bar: {
        someProperty: 'rab'
    }
};

var callbacks = {};
for (var i in myList) {
    callbacks[i] = { 
        key: i, //Add a key property
        callback: function(){ 
            myFunction( myList[this.key].someProperty ); 
            // And refer to    ^^^^^^^^
        }
    };
}

function myFunction(propertyValue) {
    console.log(propertyValue);
}

callbacks['foo'].callback(); //oof
callbacks['bar'].callback(); //rab
于 2013-09-13T13:24:45.453 回答