0

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

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 循环时,警报返回未定义并添加一个带有未定义侧的复选框.. 我想我正在使用正确的初始化但混淆它为什么这样做?

4

1 回答 1

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]);
}
于 2013-03-19T19:50:32.573 回答