我写的"返回元素的所有元素兄弟节点"函数为什么不能返回作为函数实参的节点呢?

来源:3-13 封装节点关系函数

我在浪费钱

2021-09-22 19:05:45

问题描述:

para前面的元素兄弟节点能返回输出,para后面的元素兄弟节点能返回输出。为什么para自身不能被返回输出?

相关代码:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="box">
        <p>段落1</p>
        <p>段落1</p>
        <p>段落1</p>
        <p>段落1</p>
        <p id="para">段落2</p>
        <p>段落3</p>
        <p>段落3</p>
        <p>段落3</p>
        <p>段落3</p>
    </div>
    <script>
        // 可以返回元素的所有元素兄弟节点
        function getAllElementSibling(node) {
            // 前面的元素兄弟节点
            var prevs = [];
            // 后面的元素兄弟节点
            var nexts = [];

            var o = node;
            // 遍历前面的兄弟元素节点
            while (o.previousSibling != null) {
                if (o.previousSibling.nodeType == 1) {
                    prevs.unshift(o.previousSibling);
                }
                o = o.previousSibling;
            }

            o = node;
            // 遍历后面的兄弟元素节点
            while (o.nextSibling != null) {
                if (o.nextSibling.nodeType == 1) {
                    nexts.push(o.nextSibling);
                }
                o = o.nextSibling;
            }
            // 合并前面和后面的兄弟元素进行输出
            return prevs.concat(nexts);
        }

        console.log(getAllElementSibling(para));
    </script>
</body>

</html>
写回答

1回答

好帮手慕久久

2021-09-23

同学你好,肯定不能返回参数自身。“兄弟节点”,请注意“兄弟”这个词。“我的兄弟姐妹”是不包括自己的(“自己”是自己的兄弟?),所以这里获取到的节点,也不包含参数自身。

祝学习愉快!

1

0 学习 · 17877 问题

查看课程