У меня есть веб-страница, из которой я извлекаю данные. Я могу сделать все отлично с VBA, кроме нажатия на элемент изображения, который затем отправляет форму, и создается всплывающее окно с данными.
Один из атрибутов в элементе изображения называется "productguid" и имеет строковое value =
"a12-545".
HTML-код формы выглядит так, прежде чем я нажимаю на элемент изображения с помощью мыши.
<form id="GetProductQuantitiesForAccessibleBranches" action="GetProductQuantitiesForAccessibleBranches" method="post">
<input type="hidden" name="ProductGuid" value="">
</form>
Это HTML-код ПОСЛЕ того, как я вручную нажимаю на него с помощью мыши:
<form id="GetProductQuantitiesForAccessibleBranches" action="GetProductQuantitiesForAccessibleBranches" method="post">
<input type="hidden" name="ProductGuid" value="a12-545">
</form>
Исходя из этого, я предположил, что значение productguid от элемента изображения передается в форму до ее отправки. Вот что мой код VBA выглядит так:
'Change the input element value
ie.Document.getElementById("GetProductQuantitiesForAccessibleBranches").all.item(0).value = "a12-545"
'Submit the form
ie.Document.getElementyId("GetProductQuantitiesForAccessibleBranches").Submit
В соответствии с окном Locals все события Javascript Null
. Обе строки кода запускаются без ошибок, но веб-страница не обновляется. Я что-то пропустил?
Я также попробовал просто щелкнуть элемент изображения с помощью метода .Click
, но это тоже ничего не делает.
Веб-страница защищена паролем, поэтому я не могу публиковать этот URL публично.
UPDATE:
Вот HTML в теге, который обычно щелкнут вручную, который затем отправляет форму. Может быть, здесь есть что-то, что я могу использовать?
<img alt="View Quantities At Other Locations" src="/WebOrder/Images/CheckQtys.gif"
title="View Quantities At Other Locations" class="popup"
popupdirection="upperleft" popupwidth="380"
popupcontent="#ProductQuantitiesForAccessibleBranches"
onbeforepopupcreate="onBeforePopupCreate_GetProductQuantitiesForAccessibleBranches(this)"
popupajaxformid="GetProductQuantitiesForAccessibleBranches"
onbeforepopupajaxpost="onBeforePopupAjaxPost_GetProductQuantitiesForAccessibleBranches(this)"
oncompletepopupajaxpost="onCompletePopupAjaxPost_GetProductQuantitiesForAccessibleBranches(this)"
productguid="a12-545"
displayitem="33902"
brandguid="00000000-0000-0000-0000-000000000000"
brandname="" brandsku="">
Дайте этот снимок, я сомневаюсь, что это будет "идеальным" ответом без фактического просмотра сайта. Тем не менее, это должно найти правильный тег изображения, если у вас нет фреймов/фреймов (пожалуйста, проверьте, нет ли их), и нажмите его.
Public Sub Click_IMG_Tag()
Dim Elements As Object
Dim Element As Object
'Get a pointer to IE etc first, I'm assuming this is already done
Set Elements = IE.Document.getElementsByTagName("img")
For Each Element In Elements
On Error Resume Next ' used to bypass elements that don't have .Title property
' later, you should error handle this exception
If Element.Title = "View Quantities At Other Locations" Then
Element.Focus
Element.Click
Element.FireEvent ("OnClick")
IELoad IE
Exit For
End If
Next
End Sub
Public Sub IELoad(Browser As Object)
While Browser.busy Or Browser.Readystate <> 4
Application.Wait (Now() + TimeValue("00:00:01"))
DoEvents
Wend
End Sub