JQ中的$(document).ready()大家应该用的非常多,基本每个JS脚本中都有这个函数的出现有时甚至会出现多个,那么另一个加载函数$(window).load相对出现的次数就很少了,下面为大家介绍一下两者的区别与他们的执行顺序@H_502_1@
一般情况下一个页面响应加载的基本顺序是:
域名解析 -> 加载html -> 加载js和css -> 加载图片等其他信息
。 那么我们在编写JS脚本时什么情况下使用$(document).ready()又在什么情况下使用$(window).load呢,我们先来了解一下两者的功能@H_502_1@一、$(document).ready()@H_502_1@
从字面的意思上理解,就是文档准备好了。也就是浏览器已经加载并解析完整个html文档,dom树已经建立起来了,然后执行此函数@H_502_1@
原生JavaScript中的写法如下:@H_502_1@
jQuery中的写法如下:@H_502_1@
或@H_502_1@
二、$(window).load@H_502_1@
在网页中所有元素(包括页面中图片,css文件等所有关联文件)完全加载到浏览器后才执行@H_502_1@
原生JavaScript中的写法如下:@H_502_1@
jQuery中的写法如下:@H_502_1@
两者的区别在于:@H_502_1@
1.执行时间不同@H_502_1@
$(document).ready()是在页面完成HTML的加载并建立了DOM树之后就开始执行,但这并不代表页面的所@H_502_1@
有数据已经全部加载完成,一些大的图片有会在建立DOM树之后很长一段时间才行加载完成,而@H_502_1@
$(window).load()就是整个页面已经加载完毕后才执行,包括图片等一些关联文件。@H_502_1@
$(document).ready()可以在JavaScript代码中出现多次,并且里面的函数或者代码都可以执行;而$(window).load()只能在JavaScript代码中出现一次,如果有多个$(window).load(),那么只有最后一个$(window).load()里面的函数或者代码才会执行,之前的$(window).load()都将被覆盖;@H_502_1@
3.执行的效率不同@H_502_1@
如要在dom的元素节点中添加onclick属性节点,这时用$(document).ready()就要比用$(window).load()的效率高;但是在某些时候还必须得用$(window).load()才行@H_502_1@
总结一下就是:$(window).load()在$(document).ready之后执行,且页面中所有内容全部加载完成后才会执行,两者的使用时机一目了然,大家可以自行决定。@H_502_1@次数不同
@H_502_1@