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");
});
}
}
答案 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;