情形:
- 网页中有一个select元素(设其id为:selectid)
- 页面脚本对其赋予了change方法:<script>$function(){$('selectid').change(...).change()}</script>
- 需要在webbrowser中进行模拟赋值,并使用webbrowser调用change方法
尝试:
- 失败方法:webbrowser.docunment.getElementByID("selectid").invokeMember("change")
- 失败方法:webbrowser.Document.InvokeScript("$('#f_yyDate').change()");
解决:
HtmlElement ele = wb.Document.CreateElement("script");
ele.SetAttribute("type", "text/javascript");
string funstr = "function refreshweb() {$('#selectid').change();}";
ele.SetAttribute("text", funstr);
wb.Document.Body.AppendChild(ele);
Object jscriptObj = wb.Document.InvokeScript("refreshweb");
这篇博客探讨了如何在WebBrowser控件中模拟触发HTML元素的change事件。作者遇到一个问题,即无法直接通过invokeMember('change')或InvokeScript调用已附加到select元素的change方法。为了解决这个问题,他们创建了一个新的JavaScript函数,将其插入到页面中,然后通过InvokeScript执行该函数,成功触发了change事件。这个解决方案对于那些需要在不支持直接调用事件的环境中操作DOM元素的情况非常有用。

7095

被折叠的 条评论
为什么被折叠?



