forEach method of Node.childNodes?

前端 未结 2 752
时光取名叫无心
时光取名叫无心 2020-11-28 14:31

After providing an incorrect answer concerning the .item() property of Node.childNodes for a question, I inspected __proto__ of the returned

相关标签:
2条回答
  • 2020-11-28 14:52

    Is the method available only at relatively recent versions of Chrome / Chromium? If yes, is this documented?

    Yes, this is new in DOM4, so not widely available.

    Is there any documentation concerning the forEach() method of Node.childNodes?

    See Add support for [ArrayClass] and use that on NodeList on the Chromium bug tracker:

    From https://bugs.webkit.org/show_bug.cgi?id=81573

    http://dom.spec.whatwg.org/#interface-nodelist

    DOM4 specs NodeList as having Array.prototype in its prototype chain.

    Some more background for this one. [ArrayClass] allows us to do things like document.querySelectorAll('.foo').forEach etc. The patch at bugs.webkit.org has a runtime flag because it is unclear if this will still be possible to achieve.

    Historically these array-like objects did not include these methods from the array prototype, leading to code like Array.prototype.forEach.call(nodeList, function() { ... }). This is now meant to change in DOM4.

    0 讨论(0)
  • 2020-11-28 15:04

    DOM4 now defines NodeList as an iterable:

    iterable<Node>;
    

    According to the IDL draft, that means

    An interface can be declared to be iterable by using an iterable declaration (matching Iterable) in the body of the interface.

    iterable<value-type>;
    iterable<key-type, value-type>;
    

    Objects implementing an interface that is declared to be iterable support being iterated over to obtain a sequence of values.

    Note: In the ECMAScript language binding, an interface that is iterable will have “entries”, “forEach”, “keys”, “values” and @@iterator properties on its interface prototype object.

    If a single type parameter is given, then the interface has a value iterator and provides values of the specified type.

    0 讨论(0)
提交回复
热议问题