jQuery中DOM操作原则实例分析


Posted in jQuery onAugust 01, 2019

本文实例讲述了jQuery中DOM操作原则。分享给大家供大家参考,具体如下:

一丶Get and Set in One(读写一体) 原则

为了更加易于使用,jQuery提供了简洁的DOM操作API,其方法往往是读写一体的。也就是说,某个方法既可用于读取操作,也可用于设置操作。如果没有为其传入表示值的参数,则表示获取操作,将返回获取到的数据;如果为其传入了表示值的参数,则表示设置操作,它将设置DOM元素指定属性的值。

示例代码

// 没有传入value参数,返回第一个匹配元素的value元素
var $a = $("a");
//只会取第一个匹配的
var $color = a.css("color");
//// 传入了value参数,设置所有匹配元素的color样式为"red"
$a.css("color", "red");

二丶Get first Set all(读取第一个,写操作所有) 原则

jQuery对象几乎所有的DOM操作方法都遵守”Get first Set all”原则。简而言之,假设当前jQuery对象匹配多个元素,如果使用jQuery对象的方法来获取数据(“读”数据),则只会获取第一个匹配元素的数据;如果使用jQuery对象的方法来设置元素数据(“写”数据),则会对所有匹配元素都进行设置操作

示例代码

var $lis = $("ul li"); // 匹配ul元素的所有后代li元素
var $className = $lis.attr("class"); // 只获取第一个匹配的li元素的class属性
$lis.attr("class", "left"); // 将所有匹配的li元素的class属性设为"left"

三丶链式编程风格

jQuery对象的所有实例方法,在没有特殊的返回需求的情况下,一般都会返回该jQuery对象本身(或者其它jQuery对象),因此我们可以继续调用返回的jQuery对象上的方法

示例代码

$("div") // 返回一个匹配所有div元素的jQuery对象
.find("ul") // 返回匹配这些div元素中的所有后代ul元素的jQuery对象
.children() // 返回匹配这些ul元素中的所有子代元素的jQuery对象
.css("color", "red") // 为这些子代元素设置css样式"color: red,并返回当前对象本身
.hide(); // 隐藏这些子代元素,并返回当前对象本身

四丶智能DOM操作,静默容错

在JS原生DOM操作中,如果通过getElementById()getElementsByName()等方式获取不到对应的元素,那么将返回null,在null上访问属性或方法,将会抛出异常。

与此不同的是,jQuery在匹配不到对应元素时将返回一个空的jQuery对象,我们仍然可以调用jQuery对象的方法,而且并不会报错。因为jQuery会智能地处理这种情况。如果该方法用于获取数据,则返回nullundefined;如果该方法用于设置数据,则忽略设置操作,并返回该空对象本身;如果该方法用于筛选元素,则同样返回一个新的jQuery空对象

更多关于jQuery相关内容还可查看本站专题:《jQuery操作DOM节点方法总结》、《jQuery遍历算法与技巧总结》、《jQuery表格(table)操作技巧汇总》、《jQuery扩展技巧总结》、《jQuery常见经典特效汇总》、《jquery选择器用法总结》及《jQuery常用插件及用法总结》

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

jQuery 相关文章推荐
jQuery插件FusionCharts实现的MSBar2D图效果示例【附demo源码】
Mar 24 jQuery
使用jQuery.Pin垂直滚动时固定导航
May 24 jQuery
jQuery实现模糊查询的方法分析
May 10 jQuery
jQuery轮播图实例详解
Aug 15 jQuery
jQuery实现高级检索功能
May 28 jQuery
如何用webpack4.0撸单页/多页脚手架 (jquery, react, vue, typescript)
Jun 18 jQuery
jquery将json转为数据字典的实例代码
Oct 11 jQuery
jquery将信息遍历到界面上实例代码
Jan 21 jQuery
jQuery+Ajax+js实现请求json格式数据并渲染到html页面操作示例
Jun 02 jQuery
jQuery中event.target和this的区别详解
Aug 13 jQuery
jQuery实现计算器功能
Oct 19 jQuery
jquery插件实现悬浮的菜单
Apr 24 jQuery
JS/jQuery实现超简单的Table表格添加,删除行功能示例
Jul 31 #jQuery
jquery.pager.js分页实现详解
Jul 29 #jQuery
jquery.pager.js实现分页效果
Jul 29 #jQuery
jQuery-Citys省市区三级菜单联动插件使用详解
Jul 26 #jQuery
jquery-ui 进度条功能示例【测试可用】
Jul 25 #jQuery
jquery ui 实现 tab标签功能示例【测试可用】
Jul 25 #jQuery
jQuery Ajax async=>false异步改为同步时,解决导致浏览器假死的问题
Jul 22 #jQuery
You might like
在PHP中利用wsdl创建标准webservice的实现代码
2011/12/07 PHP
PHP页面中文乱码分析
2013/10/29 PHP
ThinkPHP3.2.3数据库设置新特性
2015/03/05 PHP
php检查页面是否被百度收录
2015/10/28 PHP
微信支付开发订单查询实例
2016/07/12 PHP
PHP耦合设计模式实例分析
2018/08/08 PHP
php使用gearman进行任务分发操作实例详解
2020/02/26 PHP
完美解决AJAX跨域问题
2013/11/01 Javascript
JQuery实现绚丽的横向下拉菜单
2013/12/19 Javascript
JavaScript Promise启示录
2014/08/12 Javascript
javascript异步编程代码书写规范Promise学习笔记
2015/02/11 Javascript
JS+CSS实现的蓝色table选项卡效果
2015/10/08 Javascript
微信小程序 绘图之饼图实现
2016/10/24 Javascript
浅谈layer的iframe弹窗给里面的标签赋值的问题
2016/11/10 Javascript
jQuery扩展+xml实现表单验证功能的方法
2016/12/25 Javascript
详解vue之页面缓存问题(基于2.0)
2017/01/10 Javascript
移动端界面的适配
2017/01/11 Javascript
前端页面文件拖拽上传模块js代码示例
2017/05/19 Javascript
详解Vue + Vuex 如何使用 vm.$nextTick
2017/11/20 Javascript
详解使用jQuery.i18n.properties实现js国际化
2018/05/04 jQuery
详解vue使用vue-layer-mobile组件实现toast,loading效果
2018/08/31 Javascript
JS实现京东商品分类侧边栏
2020/12/11 Javascript
Python最基本的数据类型以及对元组的介绍
2015/04/14 Python
flask中主动抛出异常及统一异常处理代码示例
2018/01/18 Python
详谈Python 窗体(tkinter)表格数据(Treeview)
2018/10/11 Python
pandas 转换成行列表进行读取与Nan处理的方法
2018/10/30 Python
kafka-python批量发送数据的实例
2018/12/27 Python
python2和python3应该学哪个(python3.6与python3.7的选择)
2019/10/01 Python
SpringBoot实现登录注册常见问题解决方案
2020/03/04 Python
*p++ 自增p 还是p所指向的变量
2016/07/16 面试题
什么是动态端口(Dynamic Ports)?动态端口的范围是多少?
2014/12/12 面试题
金属材料工程个人求职的自我评价
2013/12/04 职场文书
教师信息技术学习心得体会
2016/01/21 职场文书
创业的9条正确思考方式
2019/08/26 职场文书
CentOS安装Nginx并部署vue
2022/04/12 Servers
Oracle锁表解决方法的详细记录
2022/06/05 Oracle