访问变量打印undefined?

时间:2013-03-19 19:44:31

标签: javascript jquery closures

您好我尝试按如下方式访问变量,

for(var k=0;k<resultSet.length;k++)
{
   alert(resultSet[k]);
   $.get('/api/TagsApi/ElementsTagsIntersect?ids='+resultSet[k], function (data) {
        testingarr = [];
        for (var i = 0; i < data.length; i++) {                    
            testingarr.push(data[i]["ID"]);
        }
        for (var w = 0; w <3; w++) {
             if (($.inArray(testingarr[w], selectedloc)) > -1) {
                    var str = "<input type='checkbox' name ='test[]' value='" + resultSet[k] + "'/>" + resultSet[k] + "</br>";
                    $('#childs').append(str);
                     alert(resultSet[k]);
                    break;
                }
        }
}, 'json');

其中第一个警告显示我期望的确切值,但是当涉及内部for循环时,警报返回undefined并添加一个带有未定义边的复选框..我想我正在使用正确的初始化但是混淆了为什么它这样做?

1 个答案:

答案 0 :(得分:1)

原因是k更改了值,因此在调用内部函数时,k已经等于resultSet.length。您可以将整个事物包装在另一个函数中,并将k作为参数传递,以将其绑定到一个新变量,该变量不会随原始k而变化:

for(var k=0;k<resultSet.length;k++)
{
  (function (result) {
    $.get('/api/TagsApi/ElementsTagsIntersect?ids='+result, function (data) {
      var testingarr = [];
      for (var i = 0; i < data.length; i++) {                    
        testingarr.push(data[i]["ID"]);
      }
      for (var w = 0; w <3; w++) {
        if (($.inArray(testingarr[w], selectedloc)) > -1) {
          var str = "<input type='checkbox' name ='test[]' value='" + result + "'/>" + result + "</br>";
          $('#childs').append(str);
          break;
        }
      }
    }, 'json');
  })(resultSet[k]);
}