0

我在我的 for 循环的第一次(也是唯一一次)执行时评论了这些值。我做什么似乎并不重要......在connection.query之后,我的for循环总是被赋予一个逃避循环的值。不知道为什么。我可以提供更多的例子。任何人都知道可能发生了什么以及我如何解决这个问题?这是一个有这个问题的代码片段。我正在使用的 node.js 的 mysql 插件在这里

https://github.com/felixge/node-mysql

for (j=0;j<rows[i].movelimit;j++){
            //j=0
               sql2="SELECT x, y, land FROM map WHERE collision = 0 AND x>"+(lastX-55)+" AND x<"+(lastX+55)+" AND y>"+(lastY-55)+" AND y<"+(lastY+55)+" AND land='"+rows[i].land+"'"+restrictions;
               connection.query(sql2, function(err, move, fields) {
            //j=rows[i]movelimit 
4

1 回答 1

3

它似乎是一个异步回调。因此,j超出回调函数范围的循环变量将始终计算为在循环结束之前分配的最后一个值。另请参阅javascript 以了解循环意外行为循环内的 JavaScript 闭包——简单实用的示例

使用闭包

function getCallbackFn(index) {
    return function(err, move, fields) {
        ....
        // "index" will always point to the function argument
    };
}
for (j=0;j<rows[i].movelimit;j++) {
    var sql2 = ...
    connection.query(sql2, getCallbackFn(j));
}

更短的内联 IEFE:

for (j=0;j<rows[i].movelimit;j++) (function(j){
    var sql2 = ...
    connection.query(sql2, function(err, move, fields) {
        ....
        // "j" points to the function argument
    });
})(j);
于 2012-07-28T14:21:42.033 回答