如何使用htmlunit单击javascript按钮?

时间:2010-10-09 21:05:04

标签: java javascript htmlunit

我正在开发一个应用程序,它将使用Java中的htmlunit自动单击网页上的按钮。唯一的问题是该按钮是一个javascript按钮,因此标准的getInputByName()将不起作用。处理这个的任何建议?该按钮的代码包含在下面。

<a class="vote_1" id="1537385" href="/javascript%3Avoid%280%29/index"><img src="/images/parts/btn-vote.gif" alt="Btn-vote" /></a> 

此外,这是投票的其他代码。

<div id="content"><script type="text/javascript" src="/js/scriptFeeds/voteArticle.js"></script> 

这会导致以下javascript:

var pressed = new Array();

$j(document).ready(function() {
var nr = $j("input#number_of_articles").val();
for(var i=1; i<=nr; i++){
    $j("a.vote_"+i).click(function(){
        var article   = $j(this).attr("id");
        $j('#'+article).hide();
        if (!pressed[article]) {
            pressed[article] = "yes";
            jQuery.post('/vote-article', {
                _token: $j("#_token").val(),
                article_id: article
            },function(data) {
                $j("span.numberOfVotes_"+data.id).html(data.votes);
            }, "json");
        }
        return false;
    });
}
});

3 个答案:

答案 0 :(得分:12)

尝试将此addOn用于firefox,它会记录您的操作并为其生成HTMLUnit代码。可能会有所帮助。 http://code.google.com/p/htmlunitscripter/

答案 1 :(得分:9)

可点击图片并没有什么特别之处。这样的事情应该有效:

button = page.getHtmlElementById( "1537385" ) ;
page = button.click() ;

然后HtmlUnit将运行Javascript并返回更新的页面。

如果'a'标记的id属性不是常量,您可能需要使用XPath来抓取它。

答案 2 :(得分:5)

我的一个页面上有一个非常相似的链接。如果你可以在任何HtmlElement上调用.click(),它应该能够运行相关的Javascript。这是我的代码(从HtmlUnitScripter生成):

HtmlElement element4 = null;
Iterable<HtmlElement> iterable5 = page.getAllHtmlChildElements();
Iterator<HtmlElement> i6 = iterable5.iterator();
while(i6.hasNext())
{
    HtmlElement anElement = i6.next();
    if(anElement instanceof HtmlImage)
    {
        HtmlImage input = (HtmlImage) anElement;
        String[] elements = "http://example.com/pages/powerbutton.png".split( "/" );

        if(input.getSrcAttribute().indexOf(elements[elements.length-1] )> -1 )
        {
            element4 = input;
            break;
        }
    }
}

HtmlPage page = element4.click();