比如一个ul里面有10个li,而第3个li上有特殊的样式(比如颜色为红色,其他为黑色)。我想把其他所有li——不包括红的li——的颜色也设为红色,此时,就需要获得红li的所有兄弟节点。

兄弟,就是和你平辈的,既不是上一级也不是下一级,而且可能有比你大的(兄),也可能比你小(弟)。兄弟节点同理,下面是一个常规的获取兄弟节点的办法。

代码如下 复制代码

function siblings(elm) {
var a = [];
var p = elm.parentNode.children;
for(var i =0,pl= p.length;i<pl;i++) {
if(p[i] !== elm) a.push(p[i]);
}
return a;
}

思路:先获取此元素的父节点的所有子节点,因为所有子节点也包括此元素自己,所以要从结果中去掉自己。

还有另外一种看起来比较奇特的方法,是jQuery里面获取兄弟节点的源码:

代码如下 复制代码

function sibling( elem ) {
var r = [];
var n = elem.parentNode.firstChild;
for ( ; n; n = n.nextSibling ) {
if ( n.nodeType === 1 && n !== elem ) {
r.push( n );
}
}

return r;
}

思路:先找到此元素的父节点的第一个子节点,然后循环查找此节点的下一个兄弟节点,一直到查找完毕。

我很奇怪为什么jQuery会使用这个方法,难道这个方法比第一个方法效率更高?

经过我初步测试——1500多个li,上面两个方法效率几乎无(www.111cn.net)差别,都是几毫秒内就获取成功了。测试环境是chrome与firefox。

如果有获取所有兄弟节点的需求,可以使用以上任一方法。

当然,我会在以后的使用过程中验证以上两个方法,如果有出入,再更新吧。

JQUERY的父,子,兄弟节点查找方法

jQuery.parent(expr) 找父亲节点,可以传入expr进行过滤,比如$("span").parent()或者$("span").parent(".class")

jQuery.parents(expr),类似于jQuery.parents(expr),但是是查找所有祖先元素,不限于父元素

jQuery.children(expr).返回所有子节点,这个方法只会返回直接的孩子节点,不会返回所有的子孙节点

jQuery.contents(),返回下面的所有内容,包括节点和文本。这个方法和children()的区别就在于,包括空白文本,也会被作为一个

jQuery对象返回,children()则只会返回节点

jQuery.prev(),返回上一个兄弟节点,不是所有的兄弟节点

jQuery.prevAll(),返回所有之前的兄弟节点

jQuery.next(),返回下一个兄弟节点,不是所有的兄弟节点

jQuery.nextAll(),返回所有之后的兄弟节点

jQuery.siblings(),返回兄弟姐妹节点,不分前后

jQuery.find(expr),跟jQuery.filter(expr)完全不一样。jQuery.filter()是从初始的jQuery对象集合中筛选出一部分,而jQuery.find()

的返回结果,不会有初始集合中的内容,比如$("p"),find("span"),是从<p>元素开始找<span>,等同于$("p span")
from:http://www.111cn.net/wy/jquery/53761.htm

最新文章

  1. DataTable的orderby有关问题
  2. 用Kotlin开发Android应用(IV):定制视图和Android扩展
  3. makeimg
  4. 淘宝(阿里百川)手机客户端开发日记第九篇 Looper详解
  5. HelloWorld之jetty运行
  6. SCAU 10678 神奇的异或
  7. curl模拟浏览器进行phpQuery抓取数据
  8. C# 操作数据库的几种方式(数据库使用SQL SERVER2008)
  9. View获取焦点
  10. [转]整理jquery开发技巧
  11. 【LeetCode题解】动态规划:从新手到专家(一)
  12. JavaScript之节点的创建、替换、删除、插入
  13. d3.js做的柱状图
  14. git 错误解决
  15. python简述
  16. 【golang】kafka
  17. 底层代码创建GUI
  18. 第 8 章 容器网络 - 049 - 准备 Overlay 网络实验环境
  19. centos 中设置网卡等相关参数
  20. springboot自定义banner生成器

热门文章

  1. phpstudy 开启apache反向代理
  2. js - 关于循环
  3. 两个自定义对象List列表取交集(intersection)
  4. 在TQ2440开发板上ping 127.0.0.1不通
  5. TP - 001
  6. Android下雪动画的实现
  7. python解析命令行参数
  8. python中string和十六进制、二进制互转
  9. shell语法使用
  10. APP注册邀请码