jQuery中DOM操作原则实例分析

 更新时间:2019年08月01日 11:05:39   作者:迎着冷眼与嘲笑  
这篇文章主要介绍了jQuery中DOM操作原则,结合实例形式分析了jQuery针对dom元素操作的四种常见原则,需要的朋友可以参考下

本文实例讲述了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程序设计有所帮助。

相关文章

  • ztree实现左边动态生成树右边为内容详情功能

    ztree实现左边动态生成树右边为内容详情功能

    zTree 是利用 JQuery 的核心代码,实现一套能完成大部分常用功能的 Tree 插件。接下来通过本文给大家分享ztree实现左边动态生成树右边为内容详情功能,需要的朋友参考下吧
    2017-11-11
  • jQuery实现对象转为url参数的方法

    jQuery实现对象转为url参数的方法

    这篇文章主要介绍了jQuery实现对象转为url参数的方法,涉及jQuery针对字符串的遍历与转换操作相关技巧,需要的朋友可以参考下
    2017-01-01
  • jquery实现动态改变css样式的方法分析

    jquery实现动态改变css样式的方法分析

    这篇文章主要介绍了jquery实现动态改变css样式的方法,结合实例形式分析了jQuery动态操作css样式的设置、获取及应用等相关操作技巧,需要的朋友可以参考下
    2019-05-05
  • JQuery打造PHP的AJAX表单提交实例

    JQuery打造PHP的AJAX表单提交实例

    本实例只利用到JQuery类库本身的函数和功能,不需要第三方插件的支持。另外,所有表单信息都是利用PHPMailer类库邮件的形式发送给管理员。
    2009-11-11
  • jQuery内存泄露解决办法

    jQuery内存泄露解决办法

    这篇文章主要为大家详细介绍了jQuery内存泄露解决办法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-12-12
  • jQuery使用ajax_动力节点Java学院整理

    jQuery使用ajax_动力节点Java学院整理

    这篇文章主要为大家详细介绍了jQuery使用ajax的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • jquery实现textarea输入字符控制(仿微博输入控制字符)

    jquery实现textarea输入字符控制(仿微博输入控制字符)

    首先获取输入框的值然后获取输入框的值;如果字数大于500、发布按钮禁用否从发布按钮启用,感兴趣的朋友可以详细了解下哈
    2013-04-04
  • js和jQuery设置Opacity半透明 兼容IE6

    js和jQuery设置Opacity半透明 兼容IE6

    对于每一个网站前端开发人员,常常都会遇到设置div透明度的需求,比如在实现图片幻灯片切换效果经常就需要使图片淡入淡出。本文分别对原生js和jQuery在IE和其它浏览器中设置透明度的方法和相关注意事项进行总结。
    2016-05-05
  • Jquery之Ajax运用 学习运用篇

    Jquery之Ajax运用 学习运用篇

    JQuery中Ajax的运用相信很多人都已熟悉,本文主要是记录下个人实践中的应用知识,旨在加强记忆。
    2011-09-09
  • jquery的父、子、兄弟节点查找,节点的子节点循环方法

    jquery的父、子、兄弟节点查找,节点的子节点循环方法

    下面小编就为大家带来一篇jquery的父、子、兄弟节点查找,节点的子节点循环方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-12-12

最新评论