2015-10-19 106 views
4

从帖子:How to ng-click an A directive in a PhantomJS test我明白我需要创建自己的函数来点击元素,但是如何使用它?无法用Phantomjs点击元素

下面的代码给我错误TypeError: 'undefined' is not a function (evaluating 'click(obj)')

var page = require('webpage').create(); 
var url = 'http://somesite.com/document.html'; 

page.open(url, function(status) { 
    page.evaluate(function() { 
     var obj = document.querySelectorAll('button')[0]; 
     click(obj); 
    }); 
    console.log(page.content); 
    phantom.exit(); 
}); 


function click(el){ 
    var ev = document.createEvent('MouseEvent'); 
    ev.initMouseEvent(
     'click', 
     true /* bubble */, true /* cancelable */, 
     window, null, 
     0, 0, 0, 0, /* coordinates */ 
     false, false, false, false, /* modifier keys */ 
     0 /*left*/, null 
    ); 
    el.dispatchEvent(ev); 
} 

回答

1

我想通了这个问题。点击正在被该网站的javascript绕过。幸运的是PhantomJS具有发送同样作为一个真正的用户将在事件的SendEvent功能:通过PhantomJS; click an element

+0

最好不要复制内容。如果解决方案为您工作,那么最好确认重复。 –

0
page.evaluate(function() { 
     document.getElementById("login").click(); 
    }); 

没有工作......没有你是什么意思?

+0

是什么。点击之间的差值(),然后单击(OBJ)

var rect = page.evaluate(function() { return $('a.whatever')[0].getBoundingClientRect(); }); page.sendEvent('click', rect.left + rect.width/2, rect.top + rect.height/2); 

找到上述解决方案? – zoltar

+0

我改变了js函数的点击 - 不是你的自定义函数。你声明“...我明白我需要创建我自己的函数来单击一个元素...”,这是不正确的,因为我明白了。 – user1515791

+3

'element.click()'不总是工作。 –

4

PhantomJS有两个上下文。只有通过page.evaluate()访问的页面上下文才有权访问DOM并可触发合成事件。由于您的click()函数使用document,因此需要在页面上下文中运行。

page.evaluate()是沙盒,这就是为什么你不能简单地使用外部定义的变量。您可能需要在页面上下文中定义它们,或者需要以复杂的方式传递它们(因为只有原始对象可以进出页面上下文,函数不是原始对象)。

page.open(url, function(status) { 
    page.evaluate(function() { 
     if (typeof window.click !== "function") { 
      window.click = function(el){ 
       var ev = document.createEvent('MouseEvent'); 
       ev.initMouseEvent(
        'click', 
        true /* bubble */, true /* cancelable */, 
        window, null, 
        0, 0, 0, 0, /* coordinates */ 
        false, false, false, false, /* modifier keys */ 
        0 /*left*/, null 
       ); 
       el.dispatchEvent(ev); 
      } 
     } 
     var obj = document.querySelectorAll('button')[0]; 
     click(obj); 
    }); 
    console.log(page.content); 
    phantom.exit(); 
}); 

参考文献:

+0

这很有用,我不再得到TypeError消息,但它不能解决问题,即它不会导致单击该按钮。我想知道是否有某种JavaScript点击预防与我试图点击的页面进行,是这样吗? – zoltar

+1

@zoltar点击在PhantomJS中总是很棘手。你有没有通过我链接的问题的解决方案?特别是,[这个答案](http://stackoverflow.com/a/24026636/1816580)几乎总是有效。 –

+0

谢谢Artjom,这是适合我的解决方案。 – zoltar