Я использую VBA для автоматизации извлечения отчетов со структурированной веб-страницы.
У меня есть следующий блок кода, который изменяет раскрывающийся элемент для каждого элемента в массиве"
With IE
For Each itemName In itemNames()
i = i + 1
Module2.check_and_wait_for_item ("cboDistrict")
Set Dropdown = .document.getElementsByName("cboDistrict")(0)
Dropdown.Value = itemValues(i)
Dropdown.FireEvent ("onchange")
check_and_wait_for_item ("cmdRptPreview")
Set btnPreview = .document.getElementsByName("cmdRptPreview")(0)
btnPreview.Click
check_and_wait_for_item ("BtnExport")
Set HTMLDoc = .document
write_file_to_dir HTMLDoc, "C:\Users\user\Documents\____thing\", itemName & ".html"
.GoBack
Next itemName
End With
Проблема возникает с IE.GoBack. У меня есть функция, которая проверяет, завершился ли выполнение JavaScript, зацикливаясь, пока определенный элемент отсутствует на странице. «Возврат» возвращает элемент на страницу, даже если событие JavaScript еще не завершилось.
Вот почему я хочу удалить старый элемент «cmdRptPreview», прежде чем моя функция проверит, завершилось ли выполнение события JavaScript.
Есть ли способ сделать это? Цените помощь.