以浏览器装载文档为例,在页面加载完毕后,浏览器会通过 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 代码如下:

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

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

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

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

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

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

字符串"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(){
//编写代码
});

三种方式都是一样的功能,读者可以根据自己的喜好,选择其中一种。

最新文章

  1. 搭建spark环境
  2. sprint2的总结及团队贡献分
  3. Win7(32bit)下Qt5.5.0和OpenCV2.4.9环境的搭建
  4. Windows 10 for phone 离我们不远了
  5. 烂泥:SQL Server 2005数据库安装
  6. SQL ServerOVER 子句,over开窗函数,SQL SERVER 开窗函数
  7. 打饭助手之NABC
  8. 关于OpenCV做图像处理内存释放的一些问题
  9. Tyvj P3119 核电站问题 动态规划
  10. 解决Easyui1.3.3 IE8兼容性问题
  11. Machine Learning—Linear Regression
  12. Controller 里面就只应该存放这些不能复用的代码(转)
  13. JSP技术模型(五)JSP隐含变量
  14. cssradius
  15. 1.17学习jquery权威指南
  16. 基于双向BiLstm神经网络的中文分词详解及源码
  17. ASP.Net Core MVC+Ajax 跨域
  18. Linux云计算运维-MySQL
  19. 从dm_exec_query_stats系统表查询耗时的SQL语句
  20. poj1845(逆元+快速幂)

热门文章

  1. Spring Boot 整合 elasticsearch
  2. LeetCode 176. 第二高的薪水(MySQL版)
  3. 都2019年了,还问GET和POST的区别
  4. js中按钮去触发定时器,那么多次点击这个定时器会越来越快,解决方法
  5. python 练习 simple_server 判断路径及返回函数
  6. 从头认识一下docker-附带asp.net core程序的docker化部署
  7. 第三篇 Html-label标签
  8. Git命令备忘
  9. SQL 日期时间比较
  10. 用idhttp打开网页或下载文件时如何显示进度