document.ready和onload的区别
document.ready和onload的区别为:加载程度不同、执行次数不同、执行速度不同。
一、加载程度不同
1.document.ready:在DOM加载完成后就可以可以对DOM进行操作。一般情况一个页面响应加载的顺序是,域名解析-加载html-加载js和css-加载图片等其他信息。那么Dom Ready应该在“加载js和css”和“加载图片等其他信息”之间,就可以操作Dom了。
2.onload:在document文档加载完成后就可以可以对DOM进行操作,document文档包括了加载图片等其他信息。那么Dom Load就是在页面响应加载的顺序中的“加载图片等其他信息”之后,就可以操作Dom了。
二、执行次数不同
1.document.ready:document.ready可以写多个.ready,可以执行多次,第N次都不会被上一次覆盖。
2.onload:onload只能执行一次,如果有多个,那么第一次的执行会被覆盖。
三、执行速度不同
1.document.ready:onload除了要等待DOM被创建还要等到包括大型图片、音频、视频在内的所有外部资源都完全加载。如果加载图片和媒体内容花费了大量时间,用户就会感受到定义在onload事件上的代码在执行时有明显的延迟。
2.onload:document.ready函数只需对 DOM 树的等待,而无需对图像或外部资源加载的等待,从而执行起来更快。
1、加载程度不同
document.ready:是DOM结构绘制完毕后就执行,不必等到加载完毕。意思就是DOM树加载完毕就执行,不必等到页面中图片或其他外部文件都加载完毕。
onload:是页面所有元素都加载完毕,包括图片等所有元素。
2、执行次数不同
document.ready可以写多个.ready,可以执行多次,第N次都不会被上一次覆盖。
onload只能执行一次,如果有多个,那么第一次的执行会被覆盖。
3、执行速度不同
onload除了要等待DOM被创建还要等到包括大型图片、音频、视频在内的所有外部资源都完全加载。如果加载图片和媒体内容花费了大量时间,用户就会感受到定义在onload事件上的代码在执行时有明显的延迟。
document.ready函数只需对 DOM 树的等待,而无需对图像或外部资源加载的等待,从而执行起来更快。
2018-08-01 · 百度知道合伙人官方认证企业
window.onload
当一个文档完全下载到浏览器中时,会触发 window.onload 事件。这意味着页面上的全部元素对 javascript 而言都是可以访问的,这种情况对编写功能性的代码非常有利,因为无需考虑加载的次序。
$(document).ready()
通过 $(document).ready() 注册的事件处理程序,则会在 DOM 完全就绪并可以使用时调用。虽然这也意味着所有元素对脚本而言都是可以访问的,但是,缺不意味着所有关联的文件都已经下载完毕。换句话说,当 HTML 下载完成并解析为 DOM 树之后,代码就可以运行。
例:
假设有一个页面,表现的是图库,这种页面中会包含许多大型图像,我们可以通过 jQuery 隐藏、显示或以其他方式操纵这些图像。如果我们通过 onload 事件设置界面,那么用户在能够使用这个页面之前,必须要等到每一幅图像都下载完成。
如果行为尚未添加给那些具有默认行为的元素(例如链接),那么用户的交互可能会导致意想不到的结果。然而,当我们使用 $(document).ready() 进行设置时,这个界面就会更早地准备好可用的正确行为。
使用 $(document).ready() 一般来说都要优于使用 onload 事件处理程序,但必须要明确的一点是,因为支持文件可能还没有加载完成,所以类似图像的高度和宽度这样的属性此时则不一定会有效。如果需要访问这些属性,可能就得选择实现一个 onload 事件处理程序(或者更类似于 jQuery 中 .load() 的等效方法)。
推荐于2017-10-11 · 知道合伙人软件行家
ready 事件的触发,表示文档结构已经加载完成(不包含图片等非文字媒体文件)。
onload 事件的触发,表示页面包含图片等文件在内的所有元素都加载完成。
进一步的详细描述,请参阅以下资料:
http://www.php100.com/html/program/jquery/2013/0905/5954.html
window.onload
当一个文档完全下载到浏览器中时,会触发 window.onload 事件。这意味着页面上的全部元素对 javascript 而言都是可以访问的,这种情况对编写功能性的代码非常有利,因为无需考虑加载的次序。
$(document).ready()
通过 $(document).ready() 注册的事件处理程序,则会在 DOM 完全就绪并可以使用时调用。虽然这也意味着所有元素对脚本而言都是可以访问的,但是,缺不意味着所有关联的文件都已经下载完毕。换句话说,当 HTML 下载完成并解析为 DOM 树之后,代码就可以运行。