C#WebBrowser是否可以自动单击div按钮?

时间:2019-05-03 10:56:43

标签: javascript c# html

我正在C#中使用WebBrowser进行测试,我发现一个站点上有一个按钮,但是该按钮没有ID,它是一个div。

<div class="pc-image-info-box-button-btn-text pc-cursor"><i class="fa fa-heart" aria-hidden="true"></i>GO</div>

是否可以告诉WebBrowser单击此按钮? 表单启动时,WebBrowser导航到站点,然后程序等待WebBrowser完成加载,一旦加载完成,应单击按钮。

那是我现在的尝试:

            webBrowser1.Url = new Uri(textBox2.Text);

        while(webBrowser1.ReadyState != WebBrowserReadyState.Complete)
        {
            Application.DoEvents();
        }

        webBrowser1.Navigate("javascript: document.getElementsByClassName('pc-image-info-box-button-btn-text pc-cursor')[0].click();void(0);");

但这不起作用。

2 个答案:

答案 0 :(得分:0)

当然可以,但前提是您的div设置了onclick事件处理程序。

var div = document.createElement('div')
// undefined
div.onclick = function(){ console.log(':)')}
// ƒ (){ console.log(':)')}
div.click()
// :)

答案 1 :(得分:0)

看这个例子:

<html>
    <head>
    </head>
<body>
    <h2 class="text-center">example</h2>
    <div class="pc-image-info-box-button-btn-text pc-cursor" ><i class="fa fa-heart" aria-hidden="true"></i>GO</div>


</body>
    <script type="text/javascript">
        // attach function on document loaded event
        document.addEventListener('DOMContentLoaded', function(){ 

            // Your selector will be different most likely
            var element = document.getElementsByClassName('pc-image-info-box-button-btn-text')[0];

            // add click event listener to selected element
            element.addEventListener("click", clickFunc);

            // declare function which fires on click
            function clickFunc(){ alert('clicked!'); }

            // trigger  element click event
            element.dispatchEvent(new Event('click'));
        }, false);
    </script>
</html>