ReadyState check not working in IE11


New Member
Nov 23, 2013
I had automated an internal application (IE) in my company using excel macro. In the code i have used readystate property of the document object to determine whether the page is loaded or not. Now when I upgraded my IE to IE11, ready state function is not working. When googled came to know that property is removed from IE1 onwards. Not able to find any alternative for ready state. Requesting your help.

As the application is in my companys intranet, not possible to paste the URL.

Piece of code am referring to is updated below. In that ReqResWindow is the IE Object and DocObjReqRes is a document object.

Set DocObjReqRes = ReqResWindow.Document
DocObjReqResReadyState = DocObjReqRes.ReadyState
Loop Until DocObjReqResReadyState = "complete"

Some videos you may like

Excel Facts

Remove leading & trailing spaces
Save as CSV to remove all leading and trailing spaces. It is faster than using TRIM().


Active Member
Apr 29, 2010
try this if it work .....
While DocObjReqResReadyState.Busy
        Application.Wait Now + TimeValue("0:00:1")
        GoTo DoRepeatLoop


New Member
Mar 12, 2019
Hi, I have found a solution to this, not sure if others would recommend it but i found that with some pages, when you log into a page, the do until readystate_complete doesn't work. I have used the below and it works perfectly, I hope it helps you and others looking for a solution!

On Error Resume Next
If htmldoc.getElementById("myaccountpage:filterForm:searchFilterText").placeholder <> "filter on bill, property, meter & spids" Then
Application.Wait (Now + TimeValue("00:00:01"))
GoTo wait1
End If

to explain, it is looking for a certain element on the loaded page(once you have logged in), and will keep looping until it finds it, it used the 'on error resume next' function to bypass the error it throws up when it can't find the ID, it will only continue when it finds that ID (when the page has loaded)

to explain my dims:

dim IE as internet explorer
dim htmldoc as HTMLDocument
set htmldoc = ie.document

i have used the 'get elementbyID but i'm sure it will work with getelementbyclassname or other get element functions.

the .placeholder refers to text within text box HTML of that ID below:

<input name="myaccountpage:filterForm:searchFilterText" id="myaccountpage:filterForm:searchFilterText" style="width: 40%;" onkeydown="if(event.keyCode==13){return false;}" type="text" <u=""> placeholder="filter on bill, property, meter & spids">

I do hope my explanation helps others with this issue as i couldn't find a solid answer anywhere, I had to come up with this myself!
Last edited:

Watch MrExcel Video

Forum statistics

Latest member

This Week's Hot Topics

  • Timer in VBA - Stop, Start, Pause and Reset
    [CODE=vba][/CODE] Option Explicit Dim CmdStop As Boolean Dim Paused As Boolean Dim Start Dim TimerValue As Date Dim pausedTime As Date Sub...
  • how to updates multiple rows in muliselect listbox
    Hello everyone. I need help with below code. code is only chaning 1st row in mulitiselect list box. i know issue with code...
  • Delete Row from Table
    I am trying to delete a row from a table using VBA using a named range to find what I need to delete. My Range is finding the right cell. In the...
  • Assigning to a variable
    I have a for each block where I want to assign the value in column 5 of the found row to the variable Serv. [CODE=vba] For Each ws In...
  • Way to verify information
    Hi All, I don't know what to call this formula, and therefore can't search. I have a spreadsheet with information I want to reference...
  • Active Cell Address – Inactive Sheet
    How to use VBA to get the cell address of the active cell in an inactive worksheet and then place that cell address in a location on the current...