应用jquery时 ready是一个非常常用的方法,我们常常会写 $(document).ready(function) 或 $(function) ready的作用 window.onload 必须等到页面内包括图片的所有元素加载完毕后才能执行,如果网页上有大量的图片,效果可想而知,用户可能在没有看到图片的时候,就已经开始操作页面了 所以window.onload 很难满足我们的需求 而ready是DOM结构绘制完毕后就执行,不必等到加载完毕 ready是如何实现的? ready是浏览器兼容的,那么就分为两种情况 (1)标准浏览器 标准浏览器非常简单,有 DOMContentLoaded 事件,当所有DOM解析完以后会触发这个事件 (2)非标准浏览器 非标准浏览器麻烦一些,jquery用两个方式来保证 1)如果浏览器存在 document.onreadystatechange 事件,当该事件触发时,如果 document.readyState=complete 的时候,可视为 DOM 树已经载入 不过这个事件不太可靠,比如当页面中存在图片的时候,可能反而在 onload 事件之后才能触发,所以不能完全指望此方法 2)doScroll检测 IE浏览器文档中说明,当页面 DOM 未加载完成时,调用 doScroll 方法时,会产生异常
那么我们反过来用,如果不异常,那么就是页面DOM加载完毕了,可以不断地通过能否执行 doScroll 判断 DOM 是否加载完毕