无法获取控制台.log在 CasperJS 中评估内部工作



我正在使用 casperjs 测试一些东西,我在调试简单的东西时遇到麻烦,我想运行一个控制台.log在评估中,阅读一些示例但仍然无法让它工作。这是我的测试代码:

var casper = require("casper").create();
var system = require('system');
var url = casper.cli.get(0);
var casper = require('casper').create({
    verbose: true,
    logLevel: "debug"
});
casper.onConsoleMessage = function(msg) {
    system.stderr.writeLine('console: ' + msg);
};
casper.start(url, function () {
    this.evaluate(function() { console.log('test'); });
});
casper.run(function() {
    console.log('done');
    this.exit();
});
我确实打印了"

完成",但从未打印过"测试",我做错了什么?

刚刚找到解决方案,我正在使用 phantomjs 的方法,我必须使用

casper.on('remote.message', function(msg) {
    this.echo('remote message caught: ' + msg);
})

而不是onConsoleMessage

您也可以

尝试以下解决方案

//Code to display Console errors
casper.on('remote.message', function (msg) {
     console.log('remote message caught: ' + msg);
 });
//Code to display errors from the page
 casper.on('page.error', function (msg, trace) {
     console.log('Error: ' + msg, 'ERROR');
 });

最新更新