phantomjs page.evaluation不能登录到控制台。[英] phantomjs page.evaluate not logging onto console

问题描述

我是 PhantomJs 新手.刚刚在这个网站上查看了一个类似的帖子.我的问题是为什么 'foo' 没有记录到控制台或打印?

var page = require('webpage').create()
var foo = 42;

function evaluate(page, func) {
    var args = [].slice.call(arguments, 2);
    var fn = "function() { return (" + func.toString() + ").apply(this, " + JSON.stringify(args) + ");}";
    return page.evaluate(fn);
}

page.open('http://google.com', function() {
  var foo = 42;
  evaluate(page, function(foo) {
  console.log(foo);
        },foo);

});

推荐答案

调用 page.evaluate() 在沙箱中运行您的评估代码.沙盒的控制台与 PhantomJS 的控制台不同.

添加到脚本的以下行会将页面的控制台打印到标准错误.

var system = require('system');

page.onConsoleMessage = function(msg) {
    system.stderr.writeLine('console: ' + msg);
};

更完整的实现是:

var page = require('webpage').create()
var system = require('system');
var foo = 42;

page.onConsoleMessage = function(msg) {
  system.stderr.writeLine( 'console: ' + msg );
};

function evaluate(page, func) {
  var args = [].slice.call(arguments, 2);
  var fn = "function() { return (" + func.toString() + ").apply(this, " +     JSON.stringify(args) + ");}";
  return page.evaluate(fn);
}

page.open(
  'http://google.com',
  function() {
    var foo = 42;
    evaluate(
      page,
      function(foo) {
        console.log(foo);
      },
      foo
    );

    console.log( "Done" );

    phantom.exit( 0 ); // must exit somewhere in the script
  }
);

输出:

$ phantomjs /tmp/idiot.js 
console: 42
Done

顺便说一句,如果您只想对评估函数进行沙盒测试,可以使用"about:blank"作为 URL 调用 page.open.

本文地址:https://www.itbaoku.cn/post/1739867.html