我写的"返回元素的所有元素兄弟节点"函数为什么不能返回作为函数实参的节点呢?
来源: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回答
同学你好,肯定不能返回参数自身。“兄弟节点”,请注意“兄弟”这个词。“我的兄弟姐妹”是不包括自己的(“自己”是自己的兄弟?),所以这里获取到的节点,也不包含参数自身。
祝学习愉快!
相似问题