我正在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);");
但这不起作用。
答案 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>