通过page.evaluate传递参数

我正在使用PhantomJS

page.evaluate()进行抓取。我的问题是我传递到Webkit页面的代码是沙盒化的,因此无法访问我的主要幻象脚本的变量。这使得很难使抓取代码通用。

page.open(url, function() {

var foo = 42;

page.evaluate(function() {

// this code has no access to foo

console.log(foo);

});

}

如何将参数推入页面?

回答:

我遇到了确切的问题。可以使用一些技巧,因为它page.evaluate也可以接受字符串。

有几种方法可以执行此操作,但是我使用了一个称为的包装器evaluate,该包装器接受其他参数以传递给必须在Webkit端进行评估的函数。您可以这样使用它:

page.open(url, function() {

var foo = 42;

evaluate(page, function(foo) {

// this code has now has access to foo

console.log(foo);

}, foo);

});

这是evaluate()函数:

/*

* This function wraps WebPage.evaluate, and offers the possibility to pass

* parameters into the webpage function. The PhantomJS issue is here:

*

* http://code.google.com/p/phantomjs/issues/detail?id=132

*

* This is from comment #43.

*/

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.evaluate传递参数 的全部内容, 来源链接: utcz.com/qa/434984.html

回到顶部