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高级程序设计 阅读笔记(十八) js跨平台的事件
Aug 14 Javascript
js修改input的type属性问题探讨
Oct 12 Javascript
node.js中的http.request.end方法使用说明
Dec 10 Javascript
angularJS 中$attrs方法使用指南
Feb 09 Javascript
详解JavaScript中void语句的使用
Jun 04 Javascript
jquery实现文字单行横移或翻转(上下、左右跳转)
Jan 08 Javascript
JavaScript 完成注册页面表单校验的实例
Aug 19 Javascript
基于iScroll实现内容滚动效果
Mar 21 Javascript
vue-cli项目根据线上环境分别打出测试包和生产包
May 23 Javascript
微信小程序实现跑马灯效果完整代码(附效果图)
May 30 Javascript
webpack里使用jquery.mCustomScrollbar插件的方法
May 30 jQuery
jquery实现简单拖拽效果
Jul 20 jQuery
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 5.3.0 安装分析心得
2009/08/07 PHP
PHP通过header实现文本文件下载的代码
2010/08/08 PHP
php设计模式 Prototype (原型模式)代码
2011/06/26 PHP
使用PHPMyAdmin修复论坛数据库的图文方法
2012/01/09 PHP
thinkPHP基于ajax实现的菜单与分页示例
2016/07/12 PHP
thinkphp3.2实现在线留言提交验证码功能
2017/07/19 PHP
php mysql PDO 查询操作的实例详解
2017/09/23 PHP
PHP+Redis开发的书签案例实战详解
2019/07/09 PHP
Yii框架学习笔记之应用组件操作示例
2019/11/13 PHP
使用js获取QueryString的方法小结
2010/02/28 Javascript
Javascript insertAfter() 实现函数代码
2011/10/12 Javascript
textarea 控制输入字符字节数(示例代码)
2013/12/27 Javascript
JS+CSS实现Li列表隔行换色效果的方法
2015/02/16 Javascript
JavaScript操作select元素和option的实例代码
2016/01/29 Javascript
AngularJS模块详解及示例代码
2016/08/17 Javascript
JS如何生成一个不重复的ID的函数
2016/12/25 Javascript
jQuery实现用户输入自动完成功能
2017/02/13 Javascript
解决React Native端口号修改的方法
2017/07/28 Javascript
JavaScript数据结构之双向链表定义与使用方法示例
2017/10/27 Javascript
vue.js+elementUI实现点击左右箭头切换头像功能(类似轮播图效果)
2019/09/05 Javascript
vuex根据不同的用户权限展示不同的路由列表功能
2019/09/20 Javascript
Vue.js页面中有多个input搜索框如何实现防抖操作
2019/11/04 Javascript
python列表去重的二种方法
2014/02/14 Python
Python实现的端口扫描功能示例
2018/04/08 Python
解决PyCharm import torch包失败的问题
2018/10/13 Python
详解Python:面向对象编程
2019/04/10 Python
python 实现二维列表转置
2019/12/02 Python
Pytorch 实现冻结指定卷积层的参数
2020/01/06 Python
python让函数不返回结果的方法
2020/06/22 Python
python利用paramiko实现交换机巡检的示例
2020/09/22 Python
python中round函数保留两位小数的方法
2020/12/04 Python
在html5的Canvas上绘制椭圆的几种方法总结
2013/01/07 HTML / CSS
boostrap modal 闪现问题的解决方法
2020/09/01 HTML / CSS
越南母婴用品购物网站:Kids Plaza
2020/04/09 全球购物
PHP解析URL是哪个函数?怎么用?
2013/05/09 面试题
秋季红领巾广播稿
2014/01/27 职场文书