Edge および Internet Explorer の HTMLCollections に関する Array.forEach の問題を修正する方法

Mary-Kate Olsen
リリース: 2024-10-20 06:42:02
オリジナル
775 人が閲覧しました

How to Fix Array.forEach Issues with HTMLCollections in Edge and Internet Explorer?

Edge および Internet Explorer の HTMLCollection に関する Array.forEach の問題

概要:

DOM querySelectorAll などのコレクションのプロパティおよびメソッドは、コレクション、特に NodeList (querySelectorAll の場合) または HTMLCollections (getElementsByTagName などのメソッドの場合) を返します。これらのコレクションは、その機能において通常の配列とは異なります。

forEach の問題:

NodeList と HTMLCollection は、forEach メソッドをネイティブにサポートしません。これが、Microsoft の Edge ブラウザーおよび Internet Explorer ブラウザーで「オブジェクトはプロパティまたはメソッド 'forEach' をサポートしていません」というエラーが発生する理由です。

解決策:

1. NodeList の forEach をポリフィルします:

forEach を NodeList で機能させるには、次のように定義できます:

<code class="js">if (typeof NodeList !== "undefined" &amp;&amp; NodeList.prototype &amp;&amp; !NodeList.prototype.forEach) {
    NodeList.prototype.forEach = Array.prototype.forEach;
}</code>
ログイン後にコピー

2。 NodeList と HTMLCollection のポリフィルの反復性:

NodeList と HTMLCollection は反復可能に指定されているため、次を使用してポリフィルできます:

<code class="js">if (typeof Symbol !== "undefined" &amp;&amp; Symbol.iterator &amp;&amp; typeof NodeList !== "undefined" &amp;&amp; NodeList.prototype &amp;&amp; !NodeList.prototype[Symbol.iterator]) {
    Object.defineProperty(NodeList.prototype, Symbol.iterator, {
        value: Array.prototype[Symbol.iterator],
        writable: true,
        configurable: true
    });
}</code>
ログイン後にコピー

補足:

  • for-of: ポリフィルの反復性により、for-of ループ構文をコレクションに直接使用できます。
  • ライブ コレクション: HTMLCollection はライブ コレクションです。つまり、DOM への変更がコレクションに反映されます。 NodeList はライブではありません。
  • 互換性: 提供されているポリフィルは、IE11 などのネイティブ forEach サポートのないブラウザをターゲットとしています。

以上がEdge および Internet Explorer の HTMLCollections に関する Array.forEach の問題を修正する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!