I have an an MVC 2 web application that uses Master pages. In the master pages, there are several ready blocks just like the one below scattered throughout the file
$(document).ready(function () {
   ...
});
Likewise, many of my views also have multiple ready blocks scattered throughout.
I have been asked to introduce another ready block into the Master that will run last.
My question is "Is there a way to guarantee that this new ready block will run last?". My thought was that if I put it at the very bottom of the Master page that would do it but I can't seem to convince myself that this is certain.
Checking if jQuery Is Loaded With JavaScriptgetElementByID() , which selects an HTML element on the page using its ID attribute. Of course, most JavaScript programmers are familiar with the $() function from jQuery, not as an alias of document.
What is the best way to make sure javascript is running when page is fully loaded? If you mean "fully loaded" literally, i.e., all images and other resources downloaded, then you have to use an onload handler, e.g.: window. onload = function() { // Everything has loaded, so put your code here };
The Document Ready Event This is to prevent any jQuery code from running before the document is finished loading (is ready). It is good practice to wait for the document to be fully loaded and ready before working with it.
$( document ).ready() jQuery detects this state of readiness for you. Code included inside $( document ).ready() will only run once the page Document Object Model (DOM) is ready for JavaScript code to execute.
This is the jQuery's .add method that is called to push your $(document).ready()'s callback to the list of all callbacks:
add = function( args ) {
    var i, length, elem, type, actual;
    for ( i = 0, length = args.length; i < length; i++ ) {
        elem = args[ i ];
        type = jQuery.type( elem );
        if ( type === "array" ) {
            // Inspect recursively
            add( elem );
        } else if ( type === "function" ) {
            // Add if not in unique mode and callback is not in
            if ( !flags.unique || !self.has( elem ) ) {
                list.push( elem );
            }
        }
    }
}
source: jQuery's callback
So: what it basically does is pushing all the functions inside the list array and after the event has been triggered - call them in the same order and if your function has been pushed last - it will be called last.
To push it last you can declare it even in the head after including all other .js files
(just make sure that there aren't any other $(document).ready() below)
Here's a trick i use. In the Master Page, declare
var postReadyEvents = [];
Then, in the child pages, when you have a bit of code that needs to run last, do
postReadyEvents.push(function() {
    ///your stuff - I usually use this to resize a grid or something.
});
Now, in the Master Page $(document).ready(), do
for(var i = 0; i < postReadyEvents.length; i++)
{
    postReadyEvents[i]();
}
When you have $(document).ready() on both child pages and Master Pages, the child page runs first and the Master Page runs last. This approach gives you the ability to control when a certain block of code runs.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With