js を使用して div 内の CSS のマージン、パディング、高さ、境界線などを取得する方法。 document.getElementById("id").style.margin を使用して直接取得できると言えるかもしれません。ただし、あなたが言ったことは、タグに直接書かれたスタイルの属性のみを取得でき、スタイルタグの外の属性(CSSファイル内の属性など)を取得することはできません。両方の値は以下の方法で取得できます。
レンダリングの例は次のとおりです:
jsがcssの属性を取得する際、タグにstyleが無い場合はcssの属性を直接取得できないため、これを行うメソッドが必要となります。
getStyle(obj,attr) 呼び出しメソッドの説明: obj はオブジェクト、attr は属性名で、js の書き込みメソッドと互換性がある必要があります (参照: JS はスタイル名の書き込みメソッドを制御できます) )。
Js コード
コードをコピー
<script><br>//クラスの属性値を取得します<br>var divs=document.getElementById("box1");<br>function getStyle(obj,attr){</p> var ie = ! "v1";//簡易判定ie6~8<p> if(attr=="backgroundPosition"){//IE6~8はbackgroundPositionの記述方法に対応していないため、backgroundPositionX/Y<br> if(ie){ return obj.currentStyle.backgroundPositionX " " obj.currentStyle.backgroundPositionY;<br> }<br> }<br> if(obj.currentStyle){<br> return obj.currentStyle[attr];<br> }<br> else{<br> return document.defaultView.getComputedStyle(obj,null)[attr];<br> }<br>}<br>function getcss(typ){<br>alert(getStyle(divs,typ)); <br>}<br></script>