这里有新鲜出炉的 Javascript 教程,程序狗速度看过来!
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
下面小编就为大家带来一篇 js 获取元素所有兄弟节点的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
比如一个 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,上面两个方法效率几乎无差别,都是几毫秒内就获取成功了。测试环境是 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")
以上这篇 js 获取元素所有兄弟节点的实现方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持 phperz。
来源: http://www.phperz.com/article/17/0530/332046.html