jQuery的文档处理程序详解


Posted in Javascript onMay 10, 2016

本文实例讲述了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模块并编写代码,比如下面的例子:

<!DOCTYPE html PUBLIC "-//W3C//DTDXHTML 1.0 
Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
  <title>jQueryStorm ? 常见错误编程方式举例</title>
  <scriptlanguage="javascript"type="text/javascript"src="../include/jquery-1.7.1.js"></script>
</head>
<body>
<!-- 页面内容部分 ?>
<div id="divMsg" style="border:solid 1px#000000;padding:20px;"></div>
<!-- 尾部模块 -->
<script language="javascript" type="text/javascript">
  //这条语句在某些情况下会导致错误
  Document.getElementById("divMsg").innerHTML="<divstyle=\"border:solid 2px #FF0000\">动态添加的图层</div>";
</script>
</boyd>
</html>

此例子在所有的浏览器都运行良好,但是存在隐患。因为在页面加载时,就在divMsg容器中添加了一个新的div对象,也就是添加了一个dom对象,当网速变慢或者页面很大需要一定的加载时间,会出现"中止操作"的错误。

这个错误甚至曾经在Google首页、淘宝等知名网站上都出现过,因为此错误很难在测试时候发现。

所以做web开发是要记住一条真理:永远不要再dom加载时修改dom结构。

如果需要在页面加载时修改dom结构,原始的做法是通过window.onload和body.onload事件实现,比如针对上面的错误例子,可以修改为:

<script type="text/javascript">
Window.onload=function()
{
  Document.getElementById("divMsg").innerHTML="<divstyle="\border:solid 2px #FF0000\">动态添加的图层</div>";
};
</script>

具体的实现方式还有很多,应用window.onload和body.onload是因为这两个事件都是在dom加载完成并且所有页面资源加载完成后才执行的,这是最简单的做法。或者根据"document.readyState"判断dom的状态,如果是"complete"则进行某些操作,jQuery的文档处理程序$(document).ready内部正是使用的此原理。

希望本文所述对大家jquery程序设计有所帮助。

Javascript 相关文章推荐
斜45度寻路实现函数
Aug 20 Javascript
33种Javascript 表格排序控件收集
Dec 03 Javascript
Mac地址验证的javascript代码
Nov 09 Javascript
jquery判断浏览器后退时候弹出消息的方法
Aug 11 Javascript
javascript+ajax实现产品页面加载信息
Jul 09 Javascript
jQuery实现图片走马灯效果的原理分析
Jan 16 Javascript
关于backbone url请求中参数带有中文存入数据库是乱码的快速解决办法
Jun 13 Javascript
js is_valid_filename验证文件名的函数
Jul 19 Javascript
Angular.js中window.onload(),$(document).ready()的写法浅析
Sep 28 Javascript
js中split()方法得到的数组长度问题
Jul 19 Javascript
jquery.pager.js实现分页效果
Jul 29 jQuery
微信小程序实现轮播图指示器
Jun 25 Javascript
有关easyui-layout中的收缩层无法显示标题的解决办法
May 10 #Javascript
jQuery对象与DOM对象转换方法详解
May 10 #Javascript
jQuery对象的链式操作用法分析
May 10 #Javascript
JS组件Bootstrap按钮组与下拉按钮详解
May 10 #Javascript
Bootstrap按钮下拉菜单组件详解
May 10 #Javascript
JavaScript编写页面半透明遮罩效果的简单示例
May 09 #Javascript
JavaScript编写点击查看大图的页面半透明遮罩层效果实例
May 09 #Javascript
You might like
PHP 的异常处理、错误的抛出及回调函数等面向对象的错误处理方法
2012/12/07 PHP
javascript中的location用法简单介绍
2007/03/07 Javascript
JavaScript实现拼音排序的方法
2012/11/20 Javascript
javascript中自定义对象的属性方法分享
2013/07/12 Javascript
基于socket.io和node.js搭建即时通信系统
2014/07/30 Javascript
深入理解JavaScript系列(50):Function模式(下篇)
2015/03/04 Javascript
jQuery实现平滑滚动到指定锚点的方法
2015/03/20 Javascript
Javascript+CSS3实现进度条效果
2016/10/28 Javascript
AngularJS获取json数据的方法详解
2017/05/27 Javascript
Angular实现可删除并计算总金额的购物车功能示例
2017/12/26 Javascript
Vue无限滑动周选择日期的组件的示例代码
2018/07/18 Javascript
js实现圆形显示鼠标单击位置
2020/02/11 Javascript
mapboxgl区划标签避让不遮盖实现的代码详解
2020/07/01 Javascript
使用vue构建多页面应用的示例
2020/10/22 Javascript
python使用内存zipfile对象在内存中打包文件示例
2014/04/30 Python
Python遍历指定文件及文件夹的方法
2015/05/09 Python
Python3的urllib.parse常用函数小结(urlencode,quote,quote_plus,unquote,unquote_plus等)
2016/09/18 Python
Python基于list的append和pop方法实现堆栈与队列功能示例
2017/07/24 Python
python打包压缩、读取指定目录下的指定类型文件
2018/04/12 Python
对python中raw_input()和input()的用法详解
2018/04/22 Python
详解Python中正则匹配TAB及空格的小技巧
2019/07/26 Python
Python django搭建layui提交表单,表格,图标的实例
2019/11/18 Python
OpenCV Python实现图像指定区域裁剪
2021/03/12 Python
Python获取指定网段正在使用的IP
2020/12/14 Python
美国女性卫生用品公司:Thinx
2017/06/30 全球购物
军训考核自我鉴定
2014/02/13 职场文书
奉献演讲稿范文
2014/05/21 职场文书
股东授权委托书范本
2014/09/13 职场文书
党的群众路线教育实践活动整改落实情况自查报告
2014/10/28 职场文书
12.4全国法制宣传日活动总结
2014/11/01 职场文书
先进事迹材料怎么写
2014/12/30 职场文书
给医院的感谢信
2015/01/21 职场文书
综合素质评价自我评价
2015/03/06 职场文书
社区禁毒宣传活动总结
2015/05/07 职场文书
纪录片信仰观后感
2015/06/08 职场文书
从QQtabBar看css命名规范BEM的详细介绍
2021/08/07 HTML / CSS