插件窝 干货文章 js获取当前元素所有子级元素的(js获取父级元素下面的所有子元素)

js获取当前元素所有子级元素的(js获取父级元素下面的所有子元素)

JavaScript js 获取所有子元素 子元素 children 4496    来源:插件窝    2020-12-09

以ul,li为例,获取ul下所有li标签

<ul id="nav">
    <li>一号</li>
    <li>二号</li>
    <li>三号</li>
    <li>四号</li>
</ul>
<script>
    let a=document.getElementById('nav').children   //获取ul下的所有子级
    console.log(a)
</script>

获取到的是HTMLCollection格式的,这种格式不方便我们操作(如:不能执行数组的push、concat等方法),所以我们需要将其转换成数组

1669868-20191227134707097-509393439.png


HTMLCollection --> Array 三种常用方法

es5方法(低版本浏览器使用,ie):var arr = Array.prototype.slice.call(htmlCollection);
es6方法1:let arr = [...htmlCollection]
es6方法2:let arr = Array.from(htmlCollection)

当然,如果十分不幸的,你需要兼容IE8等旧浏览器或更早版本,我们需要使用一个更基本的兼容性函数,如

function toArr(arr){
    for(var i = 0, a = []; i < arr.length; i++)
    a.push(arr[i]);
    return a;
}

1669868-20191227141517124-1486929219.png

转换成数组之后,即可使用push.concat等方法