ホームページ > 記事 > ウェブフロントエンド > IEブラウザがgetElementsByClassName_javascriptスキルをサポートしていない問題の解決策
getElementsByClassName メソッドが DOM3 に追加されましたが、IE9 と 10 以外の他のバージョンではサポートされていません。これは面倒です。
現在の解決策は、ブラウザーがこのメソッドをサポートしているかどうかを判断することです。サポートしていない場合は、そのままにしておきます。この方法には、メソッドを追加しないという利点があります。ネイティブ関数があるかどうかに関係なく、コードを変更する必要があります。
インターネット上の一部の人は getElementsByClassName 関数を直接定義していますが、この場合、コード内での document.getElementsByClassName の使用はすべて getElementsByClassName に書き換える必要があります。それはやや不便であり、普遍的ではありません。
次のメソッドはドキュメントの作成を完全にサポートします:
if(!document.getElementsByClassName){ document.getElementsByClassName = function(className, element){ var children = (element || document).getElementsByTagName('*'); var elements = new Array(); for (var i=0; i<children.length; i++){ var child = children[i]; var classNames = child.className.split(' '); for (var j=0; j<classNames.length; j++){ if (classNames[j] == className){ elements.push(child); break; } } } return elements; }; }