Home >Web Front-end >Front-end Q&A >What is the difference between jquery $(document).ready() and onload

What is the difference between jquery $(document).ready() and onload

青灯夜游
青灯夜游Original
2020-12-17 12:02:311888browse

Difference: There is no simplified writing method for window.onload. It must wait until all elements in the page, including pictures, are loaded before it can be executed. And "$(document).ready()" can be abbreviated as "$(function(){})", which is executed after the DOM structure is drawn, without having to wait until it is loaded.

What is the difference between jquery $(document).ready() and onload

Recommended tutorial: jquery video tutorial

##jquery $(document).ready( ) and window.onload

1. Execution time

window.onload must wait until all elements in the page, including images, are loaded. can be executed.

$(document).ready() is executed after the DOM structure is drawn, without having to wait until it is loaded.

2. The number of writes is different

You cannot write multiple window.onloads at the same time. If there are multiple window.onload methods, only one will be executed

$(document).ready() can be written multiple times at the same time, and all of them can be executed

3. Simplified writing method

There is no simplified writing method for window.onload

$(document).ready(function(){}) can be abbreviated as $(function(){});

Instructions:

Take the browser loading a document as an example. After the page is loaded, the browser will add events to the DOM elements through JavaScript. In regular JavaScript code, the window.onload method is usually used, while in jQuery, the $(document).ready() method is used.

$(document).ready() method and window.onload method have similar functions, but there are differences in execution timing. The window.onload method is executed after all elements in the web page (including the elements' associated files) are completely loaded into the browser, that is, JavaScript can only access any element in the web page at this time. The event handler registered through the $(document).ready() method in jQuery can be called when the DOM is completely ready. At this point, all elements of the web page are accessible to jQuery, but this does not mean that the files associated with these elements have been downloaded.

For example, there is a large photo gallery website that adds certain behaviors to all pictures in the web page, such as hiding or displaying the picture after clicking on it. If the window.onload method is used, the user must wait until each image is loaded before proceeding. If you use the $(document).ready() method in jQuery to set it up, you can operate it as soon as the DOM is ready, without waiting for all images to be downloaded. Obviously, parsing a web page into a DOM tree is much faster than loading all associated files in the web page.

Another thing to note is that since the event registered in the $(document).ready() method will be executed as long as the DOM is ready, the associated file of the element may not be downloaded at this time. For example, the HTML related to the image has been downloaded and parsed into a DOM tree, but it is very likely that the image has not been loaded yet, so attributes such as the height and width of the image may not be valid at this time. To solve this problem, you can use another page loading method in JQuery - the load() method. The load() method binds a handler function to the element's onload event. If the handler function is bound to the window object, it will be triggered after all content (including windows, frames, objects, images, etc.) is loaded. If the handler function is bound to an element, it will be triggered after the content of the element is loaded. The jQuery code is as follows:

$(window).load(function () {
    //编写代码
})

Equivalent to the following code in JavaScript:

window.onload = function () {
    //编写代码
}

Assume there are two functions in the web page, the JavaScript code is as follows:

function one() {
    alert("one");
}
function two() {
    alert("two");
}

When the web page is loaded Finally, the one function and the two function are called respectively through the Javascript code:

window.onload = one;
window.onload = two;

However, when the code is run, it is found that only the string "two" dialog box pops up.

The reason why the string "one" dialog box cannot be popped up is that JavaScript's onload event can only save a reference to one function at a time. It will automatically overwrite the previous function with the later function, so it cannot be used in the existing function. Add new behavior to the behavior.

In order to achieve the effect of sequential triggering of two functions, it can only be achieved by creating a new JavaScript method. The JavaScript code is as follows:

window.onload = function () {
    one();
    two();
}

Although the code written in this way can solve certain problems, But it still cannot meet certain needs. For example, if there are multiple JavaScript files, each file needs to use the window.onload method. In this case, it will be very troublesome to write code using the method mentioned above. You can refer to the Javascript shared onload event, and jQuery's $(document).ready() method can handle these situations well. Each call to the $(document).ready() method will append new behavior to the existing behavior. Behaviors, these behavior functions will be executed sequentially according to the order of registration. For example, the following jQuery code:

function one() {
    alert("one");
}
function two() {
    alert("two");
}
$(document).ready(function () {
    one();
});
$(document).ready(function () {
    two();
})

After running the code, the string "one" dialog box will pop up, and then the string "two" dialog box will pop up

For more programming-related knowledge, please visit:

Programming Teaching! !

The above is the detailed content of What is the difference between jquery $(document).ready() and onload. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn