$(document).ready和window.onload、$(window).load(function (){})的区别

$(document).ready:是DOM结构绘制完毕后就执行,没必要等到加载完毕。 意思就是DOM树加载完毕,就执行,没必要等到页面中图片或其余外部文件都加载完毕。而且能够写多个.ready。css

window.onload:是页面全部元素都加载完毕,包括图片等全部元素。只能执行一次。 因此,$(document).ready的执行时间要早于window.onload。而且能够写多个,看代码:框架

//如下代码没法正确执行: 
window.onload = function()
{ 
alert(“text1”); 
}; 
window.onload = function()
{ 
alert(“text2”); 
}; 
//结果只输出第二个 能同时编写多个 
//如下代码正确执行: 
$(document).ready(function()
{ 
alert(“Hello World”); 
}); 
$(document).ready(function()
{ 
alert(“Hello again”); 
}); 
//结果两次都输出

若是须要获取DOM绑定元素的属性值时,最好使用window.onload,由于他是在全部元素加载完毕才执行,若是使用$(document).ready,DOM已经加载,可是DOM绑定的元素属性没有加载,因此属性不生效。要解决这个问题,可使用 Jquery 中另外一个关于页面加载的方法 ---load() 方法。 Load() 方法会在元素的 onload 事件中绑定一个处理函数。若是处理函数绑定给 window 对象,则会在全部内容 ( 包括窗口、框架、对象和图像等 ) 加载完毕后触发,若是处理函数绑定在元素上,则会在元素的内容加载完毕后触发。函数

//Jquery 代码以下: 
$(window).load(function ()
{ 

});
//等价于 JavaScript 中的如下代码 
Window.onload = function ()
{
 
}

总结:code

  1. window.onload=function(){}是等待全部的内容都加载完以后执行,好比图片,内容,js,css等。对象

  2. $(function(){}),是等待DOM加载完以后执行(个人理解是标签绘制完毕以后),图片未加载完时也能执行。事件

  3. $(function(){})是$(document).ready(function(){})的简写方式,功能是同样的。图片

  4. $(window).load(function (){})也是等待全部的内容都加载完以后执行。ip

  5. 无论是外链js仍是页面中的js的window.onload都只执行最后的一个io

  6. $(window).load(function (){})能够有多个,并且都是顺序执行。function

相关文章
相关标签/搜索