nextSibling和nextElementSilbing使用以及解决兼容性问题

13 篇文章 1 订阅

nextSibling和nextElementSilbing使用以及解决兼容性问题

1、今天学习了 获取兄弟节点 的方法 – nextSibling(获取下一个兄弟节点)、previousSibling(获取上一个兄弟节点)
Node.nextSibling 是一个只读属性,返回其父节点的 childNodes 列表中紧跟在其后面的节点,如果指定的节点为最后一个节点,则返回 null。

<body>
    <div>啦啦啦</div>
    <div>我是div</div>
    <span>我是span</span>
    <script>
        var div = document.querySelector('div');
        // nextSibling 下一个兄弟节点 包含元素节点 文本节点
        console.log(div.nextSibling);
        console.log(div.previousSibling);
    </script>
</body>

但是结果却是…因为 nextSibing是获取下一个兄弟节点 包含元素节点 和文本节点 所以会输出—#text
Gecko内核的浏览器会在源代码中标签内部有空白符的地方插入一个文本结点到文档中.因此,使用诸如 Node.firstChild 和 Node.previousSibling 之类的方法可能会引用到一个空白符文本节点, 而不是使用者所预期得到的节点.
在这里插入图片描述

2、解决方法: 使用 nextElementSibling() 可以获取下一个兄弟节点,但是它要 ie9 以上版本才支持

<body>
    <p>我是p</p>
    <div>我是div</div>
    <span>我是span</span>
    <script>
        var div = document.querySelector('div');
        // nextSibling 下一个兄弟节点 包含元素节点 文本节点
        console.log(div.nextSibling);
        console.log(div.previousSibling);
        //2.nextElementSibling 得到下一个兄弟元素节点  但是ie9 以上支持
        console.log(div.nextElementSibling);
        console.log(div.previousElementSibling);
    </script>
</body>

结果返回了我们想要的数据
在这里插入图片描述
3、如何解决 nextElementSilbing 的兼容性问题呢?-----可以自己封装一个兼容性的函数

function getNextElementSibling(element) {
            var ele = element;
            while (ele = ele.nextSibling) {
                if (ele.nodeType === 1) {
                    return ele;
                }
            }
            return null;
        }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值