Javascript コードから要素の真の境界線、パディング、およびマージンを検出する方法はありますか? 次のコードを見ると:
<html>
<head>
<style>
<!--
.some_class {
padding-left: 2px;
border: 2px solid green;
}
-->
</style>
<script>
<!--
function showDetails()
{
var elem = document.getElementById("my_div");
alert("elem.className=" + elem.className);
alert("elem.style.padding=" + elem.style.padding);
alert("elem.style.paddingLeft=" + elem.style.paddingLeft);
alert("elem.style.margin=" + elem.style.margin);
alert("elem.style.marginLeft=" + elem.style.marginLeft);
alert("elem.style.border=" + elem.style.border);
alert("elem.style.borderLeft=" + elem.style.borderLeft);
}
-->
</script>
</head>
<body>
<div id="my_div" class="some_class" style="width: 300px; height: 300px; margin-left: 4px;">
some text here
</div>
<button onclick="showDetails();">show details</button>
</body>
</html>
ボタンをクリックすると、パディングが正しく報告されていないことがわかります。「スタイル」を介して直接定義されたプロパティのみがレポートされ、CSS クラスを介して定義されたプロパティはレポートされません。
これらのプロパティの最終値を取得する方法はありますか? すべての CSS 設定が計算され、ブラウザーによって適用された後に取得される値を意味します。