Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to detect that Google Instant page has loaded completely?

I'm working on a browser extension (think SEOQuake) - I need to display some data about the search results that are shown.

Issue: If anything is added to the Google Instant results page while it's still in the process of being loaded, it'll overwrite any additions. I caught myself writing some really wonky setInterval business (waiting until the contents of ol#rso stop changing in size, stuff like that) so I suppose that means I'm not sure how to reliably determine if the page is done loading.

I could just have it wait 1-2 seconds but I really want to start fetching the data as soon as the results are loaded to save maximum amount of time.

Edit: Keep in mind, I can't use DOMElementWhatever because IE8 doesn't support it.

like image 302
dsp_099 Avatar asked Mar 21 '13 07:03

dsp_099


1 Answers

Try this:

window.addEventListener("message", function(e) {if(e.data == 'jrc') console.log('loaded')}, false);

That should work in IE 8+ and all other browsers: http://caniuse.com/#feat=x-doc-messaging

If that doesn't work in IE 8 (can't test in on my Mac right now), let me know. I believe I got some reasonably good understanding of the rs.js in the last hour. ;)

like image 79
mrks Avatar answered Oct 06 '22 22:10

mrks



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!