无休止的谷歌搜索和许多解决方案似乎没有帮助。我不断收到各种不同类型的错误,而且找不到一种优雅的方式来单击此按钮,除非我让代码在用鼠标手动单击它时等待四秒钟。
它适用于其他按钮,但我正在工作,如果这里的问题是嵌套的 doPostBack 和其中的许多“”(由“”替换)?
下面的代码(我已经删除了不相关的部分)
VBA 代码:
Sub IE_Clicks()
Dim shellWins As ShellWindows
Dim IE As InternetExplorer
Set shellWins = New ShellWindows
If shellWins.Count > 0 Then
' Get IE
Set IE = shellWins.Item(0)
IE.Visible = True
Else
' Create IE
Set IE = New InternetExplorer
IE.Visible = True
End If
IE.Navigate ("[URL]")
Do While (IE.Busy Or IE.READYSTATE <> READYSTATE.READYSTATE_COMPLETE)
DoEvents
Loop
Call IE.document.parentWindow.execScript("WebForm_DoPostBackWithOptions(new WebForm_PostBackOptions('ctl00$cphMain$btnAddTab', '', true, '', '', false, false))", "JavaScript")
Set IE = Nothing
End Sub
HTML 代码:
<input type="submit" name="ctl00$cphMain$btnAddTab" value="Add New" onclick="javascript:WebForm_DoPostBackWithOptions(new WebForm_PostBackOptions("ctl00$cphMain$btnAddTab", "", true, "", "", false, false))" id="ctl00_cphMain_btnAddTab" class="ActionButton">
JavaScript:
<script type="text/javascript">
//<![CDATA[
var theForm = document.forms['aspnetForm'];
if (!theForm) {
theForm = document.aspnetForm;
}
function __doPostBack(eventTarget, eventArgument) {
if (!theForm.onsubmit || (theForm.onsubmit() != false)) {
theForm.__EVENTTARGET.value = eventTarget;
theForm.__EVENTARGUMENT.value = eventArgument;
theForm.submit();
}
}
//]]>
</script>
如果能让我点击这个按钮,那就太棒了。
最佳答案
这应该有效:
IE.document.getElementById("ctl00_cphMain_btnAddTab").Click
关于javascript - "Click"一个带有VBA的javascript按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41268757/