JQuery元素快速查找与操作


Posted in jQuery onApril 22, 2018

首先,我们来看看jquery中如何查找到想要的结点。

第一步:sizzle选择器

基于元素的id、类、类型、属性、属性值等"查找"(或选择)HTML元素,简单的说是基于css选择器,除此之外还有一些特定的选择器。

第二步:查询祖先

parent()

返回被选元素的直接父元素,该方法只会向上一级对 DOM 树进行遍历

parents()

可以使用可选参数来过滤对父元素的搜索
返回被选元素的所有祖先元素,它一路向上直到文档的根元素

parentsUntil()

返回介于两个给定元素之间的所有祖先元素,下面是例子:

$(document).ready(function(){

  //会返回span开始到div为止的祖先元素
  
  $("span").parentsUntil("div");
  
});

第三步:查询子孙

children()

可以使用可选参数来过滤对子元素的搜索

返回被选元素的所有直接子元素,该方法只会向下一级对 DOM 树进行遍历

find()

可以使用可选参数来过滤对元素的搜索

返回被选元素的后代元素,一路向下直到最后一个后代

第四步:查询同胞

siblings()

返回被选元素的所有同胞元素

next()

返回被选元素的下一个同胞元素

nextAll()

返回被选元素的之后的全部同胞元素

nextUntil()

返回介于两个给定参数之间的所有跟随的同胞元素

$(document).ready(function(){

  //返回介于 <h2>与<h6>元素之间的所有同胞元素
  
  $("h2").nextUntil("h6");
  
});

prev()、prevAll() 和 prevUntil()

prev()、prevAll()以及prevUntil()方法的工作方式与上面的方法类似,只不过方向相反而已:它们返回的是前面的同胞元素(在 DOM 树中沿着同胞之前元素遍历,而不是之后元素遍历)。

第五步:查询时添加过滤

first()

返回选择的元素中的首个元素

last()

返回选择的元素中的最后一个元素

eq()

返回被选元素中带有指定索引号的元素,这个很容易理解,举例就是:$(element[flag])和element.eq(flag)结果一样

filter()

对查询结果进行过滤,和下面not()类似,作用相反

not()

返回不匹配标准的所有元素

$(document).ready(function(){

  //返回不带有类名"target"的所有p元素
  
  $("p").not(".target");
  
});

元素找到以后,接着我们需要根据需求来对查找到的结点进行操作。

第六步:text()、html()、val()以及attr()

text()、html()、val()以及attr(),拥有回调函数。回调函数有两个参数:被选元素列表中当前元素的下标,以及原始(旧的)值。然后以函数新值返回您希望使用的字符串

1.text() - 设置或返回所选元素的文本内容

2.html() - 设置或返回所选元素的内容(包括 HTML 标记)

3.val() - 设置或返回表单字段的值

4.attr() - 设置或返回属性值

$("#btn1").click(function(){

  $("#test1").text(function(i,origText){
  
    return "旧文本: " + origText + " 新文本: index: " + i;
    
  });
  
});

第七步:添加元素

append() - 在被选元素的内部结尾插入内容

prepend() - 在被选元素的内部开头插入内容

after() - 在被选元素之后插入内容

before() - 在被选元素之前插入内容

第八步:删除元素

remove()可接受一个参数,允许你对被删元素进行过滤,empty()不可以

remove() - 删除被选元素(及其子元素)

empty() - 从被选元素中删除子元素

//等同于$("p.target").remove();
$("p").remove(".target");

第九步:替换元素

replaceAll()和replaceWith()功能类似,但是目标和源相反

replaceWith() - 用提供的内容替换集合中所有匹配的元素并且返回被删除元素的集合

replaceAll() - 用集合的匹配元素替换每个目标元素

第十步:class操作

addClass() - 向被选元素添加一个或多个类

removeClass() - 从被选元素删除一个或多个类

toggleClass() - 对被选元素进行添加/删除类的切换操作

hasClass() - 判断一个元素是否存在该class

第十一步:css()方法

设置或返回被选元素的一个或多个样式属性

css("propertyname"); - 返回propertyname属性的值

css("propertyname","value"); - 设置propertyname属性的值

css({"propertyname":"value","propertyname":"value",...}); - 设置多个值

第十二步:元素尺寸

width() 方法设置或返回元素的宽度(不包括内边距、边框或外边距)

height() 方法设置或返回元素的高度(不包括内边距、边框或外边距)

innerWidth() 方法返回元素的宽度(包括内边距)

innerHeight() 方法返回元素的高度(包括内边距)

outerWidth() 方法返回元素的宽度(包括内边距和边框)

outerHeight() 方法返回元素的高度(包括内边距和边框)

jQuery 相关文章推荐
jQuery+ThinkPHP+Ajax实现即时消息提醒功能实例代码
Mar 21 jQuery
jQuery实现简单漂亮的Nav导航菜单效果
Mar 29 jQuery
如何编写jquery插件
Mar 29 jQuery
jQuery+Ajax实现用户名重名实时检测
Jun 01 jQuery
jQuery实现键盘回车搜索功能
Jul 25 jQuery
解决JQuery全选/反选第二次失效的问题
Oct 11 jQuery
jQuery替换节点元素的操作方法
Mar 18 jQuery
jQuery实现遍历XML节点和属性的方法示例
Apr 29 jQuery
jQuery实现的3D版图片轮播示例【滑动轮播】
Jan 18 jQuery
jQuery分组选择器简单用法示例
Apr 04 jQuery
Jquery属性的获取/设置及样式添加/删除操作技巧分析
Dec 23 jQuery
JS JQuery获取data-*属性值方法解析
Sep 01 jQuery
关于jquery layui弹出层的使用方法
Apr 21 #jQuery
jQuery中的for循环var与let的区别
Apr 21 #jQuery
jQuery中的$是什么意思及 $. 和 $().的区别
Apr 20 #jQuery
通过jquery获取上传文件名称、类型和大小的实现代码
Apr 19 #jQuery
jQuery滚动条美化插件nicescroll简单用法示例
Apr 18 #jQuery
jQuery实现的淡入淡出与滑入滑出效果示例
Apr 18 #jQuery
jQuery实现的手动拖动控制进度条效果示例【测试可用】
Apr 18 #jQuery
You might like
PHP 截取字符串专题集合
2010/08/19 PHP
php各种编码集详解和以及在什么情况下进行使用
2011/09/11 PHP
PHP通过插入mysql数据来实现多机互锁实例
2014/11/05 PHP
thinkPHP学习笔记之安装配置篇
2015/03/05 PHP
PHP实现查询两个数组中不同元素的方法
2016/02/23 PHP
LaravelS通过Swoole加速Laravel/Lumen详解
2018/03/02 PHP
Extjs单独定义各组件的实例代码
2013/06/25 Javascript
jquery判断RadioButtonList和RadioButton中是否有选中项示例
2013/09/29 Javascript
不同Jquery版本引发的问题解决
2013/10/14 Javascript
javascript实现超炫的向上滑行菜单实例
2015/08/03 Javascript
基于jquery插件编写countdown计时器
2016/06/12 Javascript
超全面的vue.js使用总结
2017/02/12 Javascript
详解vuejs2.0 select 动态绑定下拉框支持多选
2019/04/25 Javascript
Vue.js 中的实用工具方法【推荐】
2019/07/04 Javascript
Vue 用Vant实现时间选择器的示例代码
2019/10/25 Javascript
React 父子组件通信的实现方法
2019/12/05 Javascript
[48:20]OpTic vs Serenity 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
python根据距离和时长计算配速示例
2014/02/16 Python
python连接mysql实例分享
2016/10/09 Python
深入学习Python中的上下文管理器与else块
2017/08/27 Python
python统计字母、空格、数字等字符个数的实例
2018/06/29 Python
Python3.5局部变量与全局变量作用域实例分析
2019/04/30 Python
分享8个非常流行的 Python 可视化工具包
2019/06/05 Python
python ETL工具 pyetl
2020/06/07 Python
python编写实现抽奖器
2020/09/10 Python
python自动化发送邮件实例讲解
2021/01/04 Python
pycharm配置安装autopep8自动规范代码的实现
2021/03/02 Python
html5中为audio标签增加停止按钮动作实现方法
2013/01/04 HTML / CSS
派出所所长先进事迹
2014/05/19 职场文书
教师党员岗位承诺书
2014/05/29 职场文书
中国梦演讲稿开场白
2014/08/28 职场文书
2014中学教师节广播稿
2014/09/10 职场文书
民主评议党员登记表自我评价
2014/10/20 职场文书
Python数据可视化之绘制柱状图和条形图
2021/05/25 Python
Django中session进行权限管理的使用
2021/07/09 Python
解决vue-router的beforeRouteUpdate不能触发
2022/04/14 Vue.js