如果使用了PhantomJS 2,则不再需要下面的垫片。不幸的是,CasperJS1.1-beta3还不支持它,因此您可能想要使用GitHub的master分支。
问题是PhantomJSv1.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选项包括在内,则不起作用,因为这些附加程序已附加到instagramjavascript之后,为时已晚。
注册
page.resource.received事件也可能有用。
还有一个纯粹的PhantomJS问题:为PhantomJS绑定polyfill



