CasperJS绑定问题
我试图达到一个instagram页面,但没有运气。 我不断收到错误和一个空白的截图。
错误文本:
TypeError: 'undefined' is not a function (evaluating 'a.createDescriptor.bind(null,t)')
Casperjs – 版本是1.1.0-beta3。
基本上我使用下面的代码:
var casper = require('casper').create({ verbose: true, logLevel: 'debug', pageSettings: { userAgent: 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_7_5) AppleWebKit/537.4 (KHTML, like Gecko) Chrome/22.0.1229.94 Safari/537.4' }, loadPlugins: true }); casper.on( 'page.error', function (msg, trace) { this.echo( 'Error: ' + msg, 'ERROR' ); }); casper.start('http://instagram.com/hello', function() { casper.wait(3000, function() { this.capture('screen.png'); }); }); casper.run(function() { this.exit(); });
如果使用PhantomJS 2,则不再需要垫片。 可悲的是,CasperJS 1.1-beta3目前还不支持,所以你可能想使用GitHub的master分支。
问题是PhantomJS v1.x不支持Function.prototype.bind
。 你需要添加一个垫片。 在CasperJS中它进入了page.initialized
事件处理程序。 这个垫片在instragram上适合我:
casper.on( 'page.initialized', function(){ this.evaluate(function(){ var isFunction = function(o) { return typeof o == 'function'; }; var bind, slice = [].slice, proto = Function.prototype, featureMap; featureMap = { 'function-bind': 'bind' }; function has(feature) { var prop = featureMap[feature]; return isFunction(proto[prop]); } // check for missing features if (!has('function-bind')) { // adapted from Mozilla Developer Network example at // https://developer.mozilla.org/en/JavaScript/Reference/Global_Objects/Function/bind bind = function bind(obj) { var args = slice.call(arguments, 1), self = this, nop = function() { }, bound = function() { return self.apply(this instanceof nop ? this : (obj || {}), args.concat(slice.call(arguments))); }; nop.prototype = this.prototype || {}; // Firefox cries sometimes if prototype is undefined bound.prototype = new nop(); return bound; }; proto.bind = bind; } }); });
如果垫片被导出到它自己的文件中并且通过clientScripts
选项包含,那么它是行不通的,因为那些是在javascript javascript之后附加的,这太迟了。
什么也可以工作注册page.resource.received
事件。
还有一个纯粹的PhantomJS问题: 为PhantomJS绑定polyfill