js jquery获取当前元素的兄弟级 上一个 下一个元素


Posted in Javascript onSeptember 01, 2015

var chils= s.childNodes;  //得到s的全部子节点

var par=s.parentNode;   //得到s的父节点

var ns=s.nextSbiling;   //获得s的下一个兄弟节点

var ps=s.previousSbiling;  //得到s的上一个兄弟节点

var fc=s.firstChild;   //获得s的第一个子节点

var lc=s.lastChile;   //获得s的最后一个子节点

JS获取节点父级,子级元素

先说一下JS的获取方法,其要比JQUERY的方法麻烦很多,后面以JQUERY的方法作对比。

JS的方法会比JQUERY麻烦很多,主要则是因为FF浏览器,FF浏览器会把你的换行也当作DOM元素

<div id="test">
<div></div>
<div></div>
</div>

原生的JS获取ID为test的元素下的子元素。

可以用:

var a = docuemnt.getElementById("test").getElementsByTagName_r("div");

这样是没有问题的

此时a.length=2;

但是如果我们换另一种方法

var b =document.getElementByIdx_x("test").childNodes;

此时b.length 在IE浏览器中没问题,其依旧等于2,但是在FF浏览器中则会使4,是因为FF把换行也当做一个元素了。

所以,在此,我们就要做处理了,需遍历这些元素,把元素类型为空格而且是文本都删除。

function del_ff(elem){
var elem_child = elem.childNodes;
for(var i=0; i<elem_child.length;i++){
if(elem_child[i].nodeName == "#text" && !/\s/.test(elem_child.nodeValue))
{elem.removeChild(elem_child)
}
}
}

上述函数遍历子元素,当元素里面有节点类型是文本并且文本类型节点的节点值是空的。就把他删除。

nodeNames可以得到一个节点的节点类型,/\s/是非空字符在JS里的正则表达式。前面加!,则表示是空字符

test() 方法用于检测一个字符串是否匹配某个模式.语法是: RegExpObject.test(string)

如果字符串 string 中含有与 RegExpObject 匹配的文本,则返回 true,否则返回 false。

nodeValue表示得到这个节点里的值。

removeChild则是删除元素的子元素。

之后,在调用子,父,兄,这些属性之前,调用上面的函数把空格清理一下就可以了

<div id="test">
<div></div>
<div></div>
</div>

<script>
function dom() {
var s= document.getElementByIdx_x("test");
del_ff(s);  //清理空格
var chils= s.childNodes; //得到s的全部子节点
var par=s.parentNode;  //得到s的父节点
var ns=s.nextSbiling;  //获得s的下一个兄弟节点
var ps=s.previousSbiling; //得到s的上一个兄弟节点
var fc=s.firstChild;  //获得s的第一个子节点
var lc=s.lastChile;  //获得s的最后一个子节点
}
</script>

下面介绍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 jquery获取当前元素的兄弟级 上一个 下一个元素,希望对大家有所帮助。

Javascript 相关文章推荐
一个javascript图片阅览组件
Nov 09 Javascript
Javascript this 的一些学习总结
Aug 02 Javascript
js实现简单的星级选择器提交效果适用于评论等
Oct 18 Javascript
jquery对元素拖动排序示例
Jan 16 Javascript
jquery+ajax+C#实现无刷新操作数据库数据的简单实例
Feb 08 Javascript
5个可以帮你理解JavaScript核心闭包和作用域的小例子
Oct 08 Javascript
AngularJS基础 ng-include 指令示例讲解
Aug 01 Javascript
Angular ng-class详解及实例代码
Sep 19 Javascript
js通过classname来获取元素的方法
Nov 24 Javascript
JS/HTML5游戏常用算法之碰撞检测 包围盒检测算法详解【矩形情况】
Dec 13 Javascript
elementUi vue el-radio 监听选中变化的实例代码
Jun 28 Javascript
Vue实现图书管理小案例
Dec 03 Vue.js
JavaScript常用标签和方法总结
Sep 01 #Javascript
jquery简单实现带渐显效果的选项卡菜单代码
Sep 01 #Javascript
JavaScript中innerHTML,innerText,outerHTML的用法及区别
Sep 01 #Javascript
Jquery常用的方法汇总
Sep 01 #Javascript
基于jquery css3实现点击动画弹出表单源码特效
Aug 31 #Javascript
基于jQuery实现的向下滑动二级菜单效果代码
Aug 31 #Javascript
jquery实现可点击伸缩与展开的菜单效果代码
Aug 31 #Javascript
You might like
php adodb连接带密码access数据库实例,测试成功
2008/05/14 PHP
php单文件版在线代码编辑器
2015/03/12 PHP
php修改文件上传限制方法汇总
2015/04/07 PHP
JS动画效果代码3
2008/04/03 Javascript
javascript 学习之旅 (3)
2009/02/05 Javascript
jQuery 表格插件整理
2010/04/27 Javascript
简单漂亮的js弹窗可自由拖拽且兼容大部分浏览器
2013/10/22 Javascript
jQuery中:reset选择器用法实例
2015/01/04 Javascript
JavaScript使用slice函数获取数组部分元素的方法
2015/04/06 Javascript
jquery实现左右滑动菜单效果代码
2015/08/27 Javascript
node.js+express制作网页计算器
2016/01/17 Javascript
jQuery实现元素拖拽并cookie保存顺序的方法
2016/02/20 Javascript
原生JS封装ajax 传json,str,excel文件上传提交表单(推荐)
2016/06/21 Javascript
纯js仿淘宝京东商品放大镜功能
2017/03/02 Javascript
详解VueJs异步动态加载块
2017/03/09 Javascript
史上最全JavaScript数组去重的十种方法(推荐)
2017/08/17 Javascript
js实现鼠标移动到图片产生遮罩效果
2017/10/21 Javascript
mongodb初始化并使用node.js实现mongodb操作封装方法
2019/04/02 Javascript
详解js中let与var声明变量的区别
2020/04/05 Javascript
vue实现条件叠加搜索的解决方法
2019/05/28 Javascript
小程序组件之自定义顶部导航实例
2019/06/12 Javascript
在Django的视图中使用form对象的方法
2015/07/18 Python
Python 常用 PEP8 编码规范详解
2017/01/22 Python
python3中str(字符串)的使用教程
2017/03/23 Python
python 判断文件还是文件夹的简单实例
2019/06/10 Python
Python Tkinter 简单登录界面的实现
2019/06/14 Python
python实现小世界网络生成
2019/11/21 Python
10个最常见的HTML5面试题 附答案
2016/06/06 HTML / CSS
Traffic People官网:女式花裙、上衣和连身裤
2020/10/12 全球购物
本科生职业生涯规划书范文
2014/01/21 职场文书
党的群众路线教育实践活动整改落实情况自查报告
2014/10/28 职场文书
2014年妇幼保健工作总结
2014/12/08 职场文书
2015年法务工作总结范文
2015/05/23 职场文书
比赛主持人开场白
2015/05/29 职场文书
五年级数学教学反思
2016/02/16 职场文书
动画《平凡职业成就世界最强》宣布制作OVA
2022/04/01 日漫