幻影js没有注入javascript直到循环结束

时间:2014-04-07 15:37:53

标签: javascript for-loop phantomjs

我正在尝试创建虚拟网页以尝试测试服务器上的负载平衡,我遍历100个页面元素实例并相应地创建它。我在注入JS时遇到困难,它不是为循环中的最后一个做所有吧。

for(var i=0; i<instances; i++) {
    pages.push(require('webpage').create());
}

console.log('Loading web page');
for(var i in pages) {
    pages[i].customHeaders = {
        'X-Forwarded-For': '192.111.111.'+i
    };
    var ip = '192.111.111.'+i;
    var mac = "00:00:00:00:00:"+i;
    var serial = '000000000'+i;

    console.log("Loading " + url + " in page " + i);
    pages[i].onInitialized = function() {
    if(!pages[i].injectJs("amino/VideoDisplay.js")) {
        console.log("Can not include script 'VideoDisplay.js'");
        phantom.exit(1);
    }
    if(!pages[i].injectJs("amino/TVI.js")) {
        console.log("Can not include script 'TVI.js'");
        phantom.exit(1);
    }
    if(!pages[i].injectJs("amino/PVR.js")) {
        console.log("Can not include script 'PVR.js'");
        phantom.exit(1);
    }
    if(!pages[i].injectJs("amino/CEC.js")) {
        console.log("Can not include script 'CEC.js'");
        phantom.exit(1);
    }
    if(!pages[i].injectJs("amino/Browser.js")) {
        console.log("Can not include script 'Browser.js'");
        phantom.exit(1);
    }
    if(!pages[i].injectJs("amino/AVMedia.js")) {
        console.log("Can not include script 'AVMedia.js'");
        phantom.exit(1);
    }
    if(!pages[i].injectJs("amino/AudioControl.js")) {
        console.log("Can not include script 'AudioControl.js'");
        phantom.exit(1);
    }
    if(!pages[i].injectJs("amino/ASTB.js")) {
        console.log("Can not include script 'ASTB.js'");
        phantom.exit(1);
    }
    if(!pages[i].injectJs("amino/AminoGeneric.js")) {
        console.log("Can not include script 'AminoGeneric.js'");
        phantom.exit(1);
    }

};

pages[i].viewportSize = 'width: 1280, height: 720';
    pages[i].settings.userAgent = 'Opera/9.80 (Linux sh4 ; U;  Amino; en) Presto/2.5.21 Version/10.30';
    pages[i].open(url, function () { 
    pages[i].evaluate(function(ip, mac, serial) {
        ASTB.IpAddress = ip;
        ASTB.MacAddress = mac;
        ASTB.Serial = serial
    }, ip, mac, serial);
    });
}

任何想法,我收到错误,说ASTB变量未定义

1 个答案:

答案 0 :(得分:2)

你正陷入封闭陷阱。当你有一个引用循环变量的匿名函数时,它在词法上绑定到循环中该变量的值。因此,当循环变量发生变化时,匿名函数关闭的值也会发生变化,因为它指向完全相同的变量。对.evaluate的回调也是异步的,因此它在循环完成后运行,此时i指向最后一个元素。你可以使用另一个函数强制这样的范围:

(function(i) {

   page[i].evaluate(...);

})(i);

或者你可以调用另一个函数:

evaluatePage(page, i);

...

function evaluatePage(page, i) {
    page[i].evaluate(...);
}