JS onload

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JS onload相关的知识,希望对你有一定的参考价值。

在JS中,如果希望在页面加载完成后执行某些操作的话,一般的写法如下:

window.onload = function(){// some thing to do};

但 是,onload函数的执行并不是我们通常所理解的浏览器构建完html页面对应的DOM树后立刻执行,而是要等到页面中所引用的图片等外部资源 完全下载完成后并且在浏览器中显示才执行,也就是说,如果页面中包括很多图片或者图片很大时将导致onload函数执行时间会被推迟很久,页面中基于 onload的特效或者其它相关内容将并不立刻可用,导致用户体验差。

JQUERY的提供了一个自己的类似onload方式,通过该方法实现的页面加载后 执行函数将在浏览器构建完DOM树后立刻执行,而并不需要等待图片等外部资源下载完成。

$(function(){//something to do}); (等同于写法$(document).ready() 和 $().ready() )

在$(document).ready()执行时,整个DOM文档树已经解析完成,即各个DOM元素都已经可以访问了(但是对于某些元素的某些属性 此时访问可能还不精确,如图片的宽度高度)

而window.onload会在整个文档都加载完成后才会执行,常见的就是对于页面含很多图片的情况下,必须等到图片都下载 下来后才会执行。

而$(document).ready()不会,

但是$(document).ready()中在访问某些属性是可能会遇到这种属性还没有加载完成的情况。


以上是关于JS onload的主要内容,如果未能解决你的问题,请参考以下文章

批量修改JS文件名称.

比较Backbone.js, Angular.js, Ember.js, Knockout.js

如何在一个js中调用另一个js,以及载入多个有依赖关系的js

js文件如何引用外部js

在js中获取作成者

怎么调用外部js文件?