无法从Phangomjs中的page.evaluate()到Page context(page.onConsoleMessage)获取控制台消息

时间:2013-05-31 21:36:40

标签: phantomjs

var page = require("webpage").create(),

     loginPage = "https://subscriber.hoovers.com/H/login/login.html";

page.onConsoleMessage = function (msg) {

     console.log(msg);
};

page.open(loginPage);

page.onLoadFinished = function (status) {

    var url = page.url;
    console.log("Status:  " + status);
    console.log("Loaded:  " + url);
    pageload(url);
    page.render('url.png');

}

function pageload(url) {

    if (url == loginPage) {

        console.log("From loginPage");

        page.evaluate(function () {

            console.log("From pageload");

        });
    }
}

3 个答案:

答案 0 :(得分:1)

BUG!

解决方法是分配:

window.console.log = function(msg) { alert(msg) }; 
页面内的

。评估

然后使用:

page.onAlert = function(msg) {
  console.log(msg);
};

抓住警报

答案 1 :(得分:-1)

由于一个不明原因(WebKit或PhantomJs中的Bug),console.log在page.evaluate中不起作用。

您应该更改代码以使用console.info,console.warn或console.error。

var page = require("webpage").create();
var loginPage = "https://subscriber.hoovers.com/H/login/login.html";

page.onConsoleMessage = function (msg) {
     console.log(msg);
};

page.open(loginPage);

page.onLoadFinished = function (status) {

    var url = page.url;
    console.log("Status:  " + status);
    console.log("Loaded:  " + url);
    pageload(url);
    page.render('url.png');
    phantom.exit(0);
}

function pageload(url) {

    if (url == loginPage) {
        console.log("From loginPage");
        page.evaluate(function () {
            console.info("From pageload");
        });
    }
}

答案 2 :(得分:-1)

确保您的phantomjs设置不会禁用执行javascript

page.settings.javascriptEnabled = true;