forEach is not a function error with JavaScript array

前端 未结 11 533
梦毁少年i
梦毁少年i 2020-11-29 17:11

I\'m trying to make a simple loop:

const parent = this.el.parentElement
console.log(parent.children)
parent.children.forEach(child => {
  console.log(chil         


        
相关标签:
11条回答
  • 2020-11-29 17:50

    parent.children is not an array. It is HTMLCollection and it does not have forEach method. You can convert it to the array first. For example in ES6:

    Array.from(parent.children).forEach(child => {
        console.log(child)
    });
    

    or using spread operator:

    [...parent.children].forEach(function (child) {
        console.log(child)
    });
    
    0 讨论(0)
  • 2020-11-29 17:50

    parent.children will return a node list list, technically a html Collection. That is an array like object, but not an array, so you cannot call array functions over it directly. At this context you can use Array.from() to convert that into a real array,

    Array.from(parent.children).forEach(child => {
      console.log(child)
    })
    
    0 讨论(0)
  • 2020-11-29 17:51

    A more naive version, at least you're sure that it'll work on all devices, without conversion and ES6 :

    const children = parent.children;
    for (var i = 0; i < children.length; i++){
        console.log(children[i]);
    }
    

    https://jsfiddle.net/swb12kqn/5/

    0 讨论(0)
  • 2020-11-29 17:54

    If you are trying to loop over a NodeList like this:

    const allParagraphs = document.querySelectorAll("p");
    

    I highly recommend loop it this way:

    Array.prototype.forEach.call(allParagraphs , function(el) {
        // Write your code here
    })
    

    Personally, I've tried several ways but most of them didn't work as I wanted to loop over a NodeList, but this one works like a charm, give it a try!

    The NodeList isn't an Array, but we treat it as an Array, using Array. So, you need to know that it is not supported in older browsers!

    Need more information about NodeList? Please read its documentation on MDN.

    0 讨论(0)
  • 2020-11-29 17:59

    You can use childNodes instead of children, childNodes is also more reliable considering browser compatibility issues, more info here:

    parent.childNodes.forEach(function (child) {
        console.log(child)
    });
    

    or using spread operator:

    [...parent.children].forEach(function (child) {
        console.log(child)
    });
    
    0 讨论(0)
  • 2020-11-29 18:01

    First option: invoke forEach indirectly

    The parent.children is an Array like object. Use the following solution:

    const parent = this.el.parentElement;
    
    Array.prototype.forEach.call(parent.children, child => {
      console.log(child)
    });
    

    The parent.children is NodeList type, which is an Array like object because:

    • It contains the length property, which indicates the number of nodes
    • Each node is a property value with numeric name, starting from 0: {0: NodeObject, 1: NodeObject, length: 2, ...}

    See more details in this article.


    Second option: use the iterable protocol

    parent.children is an HTMLCollection: which implements the iterable protocol. In an ES2015 environment, you can use the HTMLCollection with any construction that accepts iterables.

    Use HTMLCollection with the spread operatator:

    const parent = this.el.parentElement;
    
    [...parent.children].forEach(child => {
      console.log(child);
    });
    

    Or with the for..of cycle (which is my preferred option):

    const parent = this.el.parentElement;
    
    for (const child of parent.children) {
      console.log(child);
    }
    
    0 讨论(0)
提交回复
热议问题