Skip to content
Create a gist now

Instantly share code, notes, and snippets.

Smallest x-browser DOM Ready, ever
function r(f){/in/(document.readyState)?setTimeout(r,9,f):f()}
@galambalazs

Doesn't seem to work: http://jsbin.com/ekeba4/ (it acts as window.onload)

@dperini
dperini commented Mar 9, 2011

@galambalazs,
"window.onload" works on any browser in the planet, this can only emulate "onload" in some browsers and fail with the rest.

It absolutely does not emulate a DOM Ready in any browsers. As an "onload" event alternative is not very performant and:

window.onload = f;

is also much shorter.

@galambalazs

@diego - Right, that's what I'm saying, cause the title is "DOM Ready" but this code fails to do that.

@ded
Owner
ded commented Mar 9, 2011

yeah. i'm rethinking how this is gonna work now. be back with another implementation

@dperini
dperini commented Mar 9, 2011

I have recently removed all the UA sniffing I was using in older versions and moved my stable cross-browser solution to GitHub here:

http://github.com/dperini/ContentLoaded

maybe you can have a look at it and compare the outcome. Currently only IFRAMEs do not participate in the optimization. Suggestions are welcome !

@lukeasrodgers

Seems to work as described in Safari 5.0.5

@kajex
kajex commented Feb 29, 2012

Very nice script to my small library.
What is the license?

@ded
Owner
ded commented Feb 29, 2012

use this: https://github.com/ded/domready - it's stable with a license too

@sp42
sp42 commented Apr 24, 2013

I can not run this function with /in/.test....

@niechen
niechen commented Feb 27, 2015

this check will fail if the document stays in "interactive" stage. use /in[^t]/ instead of /in/.

@mjschutz

You have a syntax error on /in/(... must be /in/.test(... And the regex expression will return true in 'interactive ' it will only call f() when it's readyState is complete on some cases (file is on browser cache), not when it is loaded. So the best shot is:

function r(f){/(un|ing)/.test(document.readyState)?setTimeout(r,9,f):f()}

@ciscoheat

Thanks @mjschutz, your version works fine (at least on Chrome).

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Something went wrong with that request. Please try again.