jQuery events .load(), .ready(), .unload()

JavascriptJqueryEventsDom

Javascript Problem Overview


Just a simple question, for the jQuery event. Are the .load(), .ready() and .unload() run in order when the DOM is loaded? The answer seems yes when I see the jQuery Documentation.

<script type="text/javascript">

	$(window).load(function () {
		// run code
		initializeCode();
	});
	
	$(document).ready(function() {
		//run code that MUST be after initialize
	});

	$(window).unload(function() {
		Cleanup();
	});
</script>

However, the code inside the .ready() is execute before the initializeCode(); is execute, so I feel really strange. And now I have to place my code inside the .onload() method and just after the initializeCode(); line, which means to be inside the .ready() block.

Could someone explain me more about this, as I am new to jQuery?

Javascript Solutions


Solution 1 - Javascript

NOTE: .load() & .unload() have been deprecated


$(window).load();

Will execute after the page along with all its contents are done loading. This means that all images, CSS (and content defined by CSS like custom fonts and images), scripts, etc. are all loaded. This happens event fires when your browser's "Stop" -icon becomes gray, so to speak. This is very useful to detect when the document along with all its contents are loaded.

$(document).ready();

This on the other hand will fire as soon as the web browser is capable of running your JavaScript, which happens after the parser is done with the DOM. This is useful if you want to execute JavaScript as soon as possible.

$(window).unload();

This event will be fired when you are navigating off the page. That could be Refresh/F5, pressing the previous page button, navigating to another website or closing the entire tab/window.

To sum up, ready() will be fired before load(), and unload() will be the last to be fired.

Solution 2 - Javascript

window load will wait for all resources to be loaded.

document ready waits for the document to be initialized.

unload well, waits till the document is being unloaded.

the order is: document ready, window load, ... ... ... ... window unload.

always use document ready unless you need to wait for your images to load.

shorthand for document ready:

$(function(){
    // yay!
});

Solution 3 - Javascript

If both "document.ready" variants are used they will both fire, in the order of appearance

$(function(){
	alert('shorthand document.ready');
});

//try changing places
$(document).ready(function(){
	alert('document.ready');
});

Solution 4 - Javascript

Also, I noticed one more difference between .load and .ready. I am opening a child window and I am performing some work when child window opens. .load is called only first time when I open the window and if I don't close the window then .load will not be called again. however, .ready is called every time irrespective of close the child window or not.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestionEricView Question on Stackoverflow
Solution 1 - JavascriptTowerView Answer on Stackoverflow
Solution 2 - JavascriptDavid MurdochView Answer on Stackoverflow
Solution 3 - JavascriptljgwwView Answer on Stackoverflow
Solution 4 - JavascriptPraveen SinghView Answer on Stackoverflow