window.onload 与 $(document).ready() 的区别

  以浏览器装载文档为例,在页面加载完毕后,浏览器会经过 JavaScript 为 DOM 元素添加事件。在常规的 JavaScript 代码中,一般使用 window.onload 方法 ,而在 jQuery 中,使用的是 $(document).ready() 方法。$(document).ready() 方法是事件模块中最重要的一个函数,能够极大地提升 Web 应用程序的响应速度。 jQuery 就是用 $(document).ready() 方法来代替传统 JavaScript 的 window.onload 方法的。经过使用该方法,能够在 DOM 载入就绪时就对其进行操纵并调用执行它所绑定的函数。在使用过程当中,须要注意 $(document).ready() 方法和 window.onload 方法之间的细微区别。浏览器

1. 执行时机框架

  $(document).ready() 方法和  window.onload 方法有类似的功能,可是在执行时机方面是有区别的。window.onload 方法是在网页中全部的元素(包括元素的全部关联文件)彻底加载到浏览器后才执行,即 JavaScript 此时才能够访问网页中的任何元素。而经过 jQuery 中的 $(document).ready() 方法注册的事件处理程序,在 DOM 彻底就绪时就能够被调用。此时,网页的全部元素对 jQuery 而言都是能够访问的,可是,这并不意味着这些元素关联的文件都已经下载完毕。函数

  举一个例子,有一个大型的图库网站,为网页中全部图片添加某些行为,例如单击图片后让它隐藏或显示。若是使用 window.onload 方法来处理,那么用户必须等到每一幅图片都加载完毕后,才能够进行操做。若是使用 jQuery 中的 $(document).ready() 方法来进行设置,只要 DOM 就绪就能够操做了,不须要等待全部图片下载完毕。很显然,把网页解析为 DOM 树的速度比把页面中的全部关联文件加载完毕的速度快不少。网站

  另外,须要注意一点,因为在 $(document).ready() 方法内注册的事件,只要 DOM 就绪就会被执行,所以可能此时元素的关联文件未下载完。例如与图片有关的 HTML 下载完毕,而且已经解析为 DOM 树了,但颇有可能图片还未加载完毕,因此例如图片的高度和宽度这样的属性此时不必定有效。要解决这个问题,可使用 jQuery 中另外一个关于页面加载的方法——load() 方法。 load() 方法会在元素的 onload 事件中绑定一个处理函数。若是处理函数绑定给 window 对象,则会在全部内容(包括窗口、框架、对象和图像等)加载完毕后触发,若是处理函数绑定在元素上,则会在元素的内容加载完毕后触发。 jQuery 代码以下:spa

$ (window).load(function() {
  //编写代码
})
等价于 JavaScript 中的如下代码:
window.onload = function() {
  //编写代码
}

 

2. 屡次使用
假设网页中有两个函数,JavaScript 代码以下:code

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

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

当网页加载完毕后,经过以下 JavaScript 代码来分别调用 one 函数和 two 函数:对象

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

然而当运行代码后,发现只弹出字符串"two"对话框blog

字符串"one"对话框不能被弹出的缘由是 JavaScript 的 onload 事件一次只能保存对一个函数的引用,它会自动用后面的函数覆盖前面的函数,所以不能在现有的行为上添加新的行为。事件

为了达到两个函数顺序触发的效果,只能再建立一个新的 JavaScript 方法来实现 ,Javascript代码以下:图片

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

虽然这样编写代码能解决某些问题,但仍是不能知足某些需求,例若有多个 JavaScript 文件,每一个文件都须要用到 window.onload 方法,这种状况下用上面提到的方法编写代码会很是麻烦。而 jQuery 的 $(document).ready() 方法可以很好地处理这些状况,每次调用 $(document).ready() 方法都会在现有的行为上追加新的行为,这些行为函数会根据注册的顺序依次执行。例如以下 jQuery 代码:

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

运行代码后,会先弹出字符串"one"对话框,而后弹出字符串"two"对话框,依次显示。

 

3. 简写方式

$(document).ready(function(){
    //编写代码
});

简写方式为:

$(function(){
    //编写代码
})

另外$(document)也能够简写为$()。当$()不带参数时,默认参数就是document,所以能够简写为:

$().ready(function(){
    //编写代码
});

三种方式都是同样的功能,读者能够根据本身的喜爱,选择其中一种。

相关文章
相关标签/搜索