javascript - "Click"一个带有VBA的javascript按钮

标签 javascript excel vba call

无休止的谷歌搜索和许多解决方案似乎没有帮助。我不断收到各种不同类型的错误,而且找不到一种优雅的方式来单击此按钮,除非我让代码在用鼠标手动单击它时等待四秒钟。

它适用于其他按钮,但我正在工作,如果这里的问题是嵌套的 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(&quot;ctl00$cphMain$btnAddTab&quot;, &quot;&quot;, true, &quot;&quot;, &quot;&quot;, 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/

相关文章:

javascript - 使用 canvas.toDataURL() 解码和保存图像

excel - 在VBA中绘制箭头超出范围

python - Pandas:如何从 CSV 或 Excel 文件读取行?

excel - 如何创建按钮来刷新数据透视表

excel - 未找到损坏的 VBA 项目模块错误

vba - 自动筛选 Excel VBA 后删除隐藏/不可见行

javascript - 'simple' 正则表达式的负后视工作

javascript - 我如何对我的数据关闭 ="modal"产生两种效果;一个重新加载父页面,而另一个不加载

javascript - 在 safari 中选择下拉文本对齐中心?

excel - 如果 VBA 中出现错误?