ID のみを使用して要素からすべてのスタイルを収集する方法
この質問では、関数 getStyleById を開発することを目的としています。 ID のみを指定して、指定された要素のすべてのスタイル属性とそれに対応する値を取得します。この関数は、インライン スタイルと CSS ファイル内で定義されたスタイルの両方を考慮する必要があります。
解決策:
これを実現するには、次のような包括的なアプローチを採用できます。
コードの実装:
<code class="javascript">function getStyleById(id) { return getAllStyles(document.getElementById(id)); } function getAllStyles(elem) { if (!elem) return []; // Empty list if element is absent. var win = document.defaultView || window, style, styleNode = []; if (win.getComputedStyle) { /* Modern browsers */ style = win.getComputedStyle(elem, ''); for (var i=0; i<style.length; i++) { styleNode.push( style[i] + ':' + style.getPropertyValue(style[i]) ); } } else if (elem.currentStyle) { /* IE */ style = elem.currentStyle; for (var name in style) { styleNode.push( name + ':' + style[name] ); } } else { /* Ancient browser..*/ style = elem.style; for (var i=0; i<style.length; i++) { styleNode.push( style[i] + ':' + style[style[i]] ); } } return styleNode; }</code>
これらのメソッドを組み込むことで、関数は、特定の要素に適用されたすべてのスタイルを効果的に収集し、さまざまなタスクでの実用性を高めます。
以上がID のみを使用して要素のすべてのスタイルを取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。