您好,欢迎来到三六零分类信息网!老站,搜索引擎当天收录,欢迎发信息

jQuery的文档处理程序详解_jquery

2024/2/27 10:28:24发布18次查看
本文实例讲述了jquery的文档处理程序。分享给大家供大家参考,具体如下:
jquery文档处理程序
所谓的文档处理程序,是指jquery中提供的$(document).ready事件,此事件会在dom加载完毕后触发,而window.onlaod和body.onload都是在页面完全加载后触发。
jquery文档处理程序介绍
在jquery中想实现在dom加载完毕后的处理逻辑,只需要使用$(document).ready()事件。此事件函数称为jquery文档处理程序。
可以在页面的任何位置,甚至是外部的js文件中,编写如下列语句:
$(document).ready(function (){ alert(document.ready)});
则在页面的dom加载完毕后,会立刻执行alert语句。如果页面上有大的图片、js文件等外部资源需要加载,jquery的文档处理程序会在其之前执行,而window.onload和boyd.onload是在所有的资源文件加载完毕后执行的。
ready()函数时jquery事件函数中提供的一个jquery对象函数,签名位ready(fn)。
fn是ready事件发生时执行的函数。
因为是jquery对象函数,意味着可以在任何jquery对象上调用:
$(body).ready(function (){ alert(body.ready)});
上面的语句等同于:
$(document).ready(function (){alert(body.ready)});
虽然ready()函数可以作用在任何jquery对象上,但是使用时一定要注意对象是否具有ready事件。
也可以使用$(fn)这种简化的形式:
$(function (){….})//等效于$(document).ready(function(){…});
同jquery中所有的事件对象一样,$(document).ready事件,会按照出现的先后顺序执行。
比如,可以调用两次$(document).ready事件:
$(document).ready(function (){alert(document.ready-1)});$(document). ready(function (){alert(document.ready-2)});
则在dom加载完毕后,首先输出document.ready-1,然后输出document.ready-2。如果使用传统的:
window.onload=function(){…..};
上面的代码会将window.onload原有的事件处理掉,然后绑定新的事件。
jquery文档处理程序的优势
如果脚本需要在页面加载时执行,那么大部分的脚本都可以放在$(document).ready()事件中。
在举例jquery文档处理程序的优势之前,先看一个常见的javascript编程错误:dom未加载完成即改变dom模型。
在传统的javascript编程中。有时会在页面的头部或者底部直接插入script模块并编写代码,比如下面的例子:
jquerystorm – 常见错误编程方式举例
此例子在所有的浏览器都运行良好,但是存在隐患。因为在页面加载时,就在divmsg容器中添加了一个新的div对象,也就是添加了一个dom对象,当网速变慢或者页面很大需要一定的加载时间,会出现中止操作的错误。
这个错误甚至曾经在google首页、淘宝等知名网站上都出现过,因为此错误很难在测试时候发现。
所以做web开发是要记住一条真理:永远不要再dom加载时修改dom结构。
如果需要在页面加载时修改dom结构,原始的做法是通过window.onload和body.onload事件实现,比如针对上面的错误例子,可以修改为:

具体的实现方式还有很多,应用window.onload和body.onload是因为这两个事件都是在dom加载完成并且所有页面资源加载完成后才执行的,这是最简单的做法。或者根据document.readystate判断dom的状态,如果是complete则进行某些操作,jquery的文档处理程序$(document).ready内部正是使用的此原理。
更多关于jquery相关内容感兴趣的读者可查看本站专题:《jquery常用操作技巧汇总》、《jquery常见事件用法与技巧总结》、《jquery操作json数据技巧汇总》、《jquery操作xml技巧总结》及《jquery扩展技巧总结》
希望本文所述对大家jquery程序设计有所帮助。
该用户其它信息

VIP推荐

免费发布信息,免费发布B2B信息网站平台 - 三六零分类信息网 沪ICP备09012988号-2
企业名录 Product