PhantomJS .click()不工作 [英] PhantomJS .click() not working
本文介绍了PhantomJS .click()不工作的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
此代码无效:
var page = require('webpage').create();
page.open('http://www.ebay.com/', function() {
console.log('Page loaded');
page.includeJs('http://ajax.googleapis.com/ajax/libs/jquery/1.8.2/jquery.min.js', function() {
console.log('jQuery included');
page.render('C:/beforeclick.jpeg');
console.log('Render 1');
page.evaluate(function() {
$('.btn-prim').click();
});
page.render('C:/afterclick.jpeg');
console.log('Render 2');
});
});
事实上,$('。btn-prim')。 jpeg和afterclick.jpeg是一样的。在浏览器控制台$('。btn-prim')。click()工作正常。 Ebay这里只是举例,它不工作在其他网站上。请帮助我解决问题,我是新手的JavaScript。
In fact $('.btn-prim').click() does not work, beforeclick.jpeg and afterclick.jpeg are the same. In browser console $('.btn-prim').click() works fine. Ebay here just for example, it does not work on other sites too. Please help me to solve the problem, I am novice in JavaScript.
推荐答案
这将给你一个适当的解决方案, / p>
This will give you a proper solution to the situation
page.evaluate(function(){
var a = document.getElementById("target_element_to_be_clicked");
var e = document.createEvent('MouseEvents');
e.initMouseEvent('click', true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
a.dispatchEvent(e);
});
希望这有助于
这篇关于PhantomJS .click()不工作的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文