javascript - getCompatedStyle 属性值

标签 javascript css getcomputedstyle

我正在尝试报告我创建的椭圆形 div 的边框半径值,但返回了一个未定义的值。谁能解释为什么?我犯了一个简单的错误还是我的代码有问题?谢谢你!

<!DOCSTYLE html>
<html>
<head>
    <title>CSS3</title>
    <style>
        #oval{
            width: 500px;
            height: 300px;
            background: black;
            border-bottom-left-radius: 50%;
            border-bottom-right-radius: 50%;
            border-top-left-radius: 50%;
            border-top-right-radius: 50%;
        }
    </style>
    <script>
        var myOval = document.getElementById('oval');
        var bRadBL = window.getComputedStyle(myOval).getPropertyValue("border-bottom-left-radius");
        var bRadBR = window.getComputedStyle(myOval).getPropertyValue("border-bottom-right-radius");
        var bRadTL = window.getComputedStyle(myOval).getPropertyValue("border-top-left-radius");
        var bRadTR = window.getComputedStyle(myOval).getPropertyValue("border-top-right-radius");
        var bRad = getComputedStyle(myOval).getPropertyValue("borderRadius");
        function compStyle(){
            alert("Top Left Radius: "+bRadTL+"\nBottom Left Radius: "+bRadBL+"\nTop Right Radius: "+bRadTR+"\nBottom Right Radius: "+bRadBR);
     }
    </script>
</head>
<body>
    <div id="oval"></div>
    <input type="button" value="click me" onClick="compStyle()"/>
</body>
</html>

编辑:我尝试过“border-bottom-left-radius”和“borderBottomLeftRadius”,但结果相同。我应该使用哪一个?

最佳答案

您在渲染元素之前运行脚本。将脚本 block 移动到正文的末尾,声明的 html 元素 id 之后:

#oval{
  width: 500px;
  height: 300px;
  background: black;;
  border-bottom-left-radius: 50%;
  border-bottom-right-radius: 50%;
  border-top-left-radius: 50%;
  border-top-right-radius: 50%;
}
<div id="oval"></div>
<input type="button" value="click me" onClick="compStyle()"/>

<script>
  var myOval = document.getElementById('oval');
  var bRadBL = window.getComputedStyle(myOval).getPropertyValue("border-bottom-left-radius");
  var bRadBR = window.getComputedStyle(myOval).getPropertyValue("border-bottom-right-radius");
  var bRadTL = window.getComputedStyle(myOval).getPropertyValue("border-top-left-radius");
  var bRadTR = window.getComputedStyle(myOval).getPropertyValue("border-top-right-radius");
  var bRad = getComputedStyle(myOval).getPropertyValue("borderRadius");
  function compStyle(){
    alert("Top Left Radius: "+bRadTL+"\nBottom Left Radius: "+bRadBL+"\nTop Right Radius: "+bRadTR+"\nBottom Right Radius: "+bRadBR);
  }
</script>

关于javascript - getCompatedStyle 属性值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32754201/

相关文章:

css - 动画过渡没有从正确的位置开始

javascript - 如何断言 HTML 元素在包含样式表后不会改变其外观?

javascript - 如何获取从父元素继承的计算背景颜色样式

javascript - Polymer:在 iron-iconset-svg 中使用 css 类

javascript - Angular ng-repeat 但重复中的指令不同

javascript - 当嵌入脚本元素时,php 的 json_encode() 是否容易受到攻击?

html - 如何将我的网站居中?

css - 跨度内的 Bootstrap 跨度

javascript - 对于给定的浏览器,通过 getComputedStyle 返回的 CSSStyleDeclaration 是否总是具有相同的长度?

javascript - Firebase:创建文档时存储服务器时间戳