zoukankan      html  css  js  c++  java
  • style currentStyle getComputedStyle的区别和用法

    先介绍下层叠样式表的三种形式:

    1.内联样式,在html标签中style属性设置。

    <p style="color:#f90">内联样式</p>
    

    2.嵌入样式,通过在head标签设置style标签添加样式。

    <style type="text/css">
        .stuff{color:#f90;}
    </style>
    

    3.外部样式,通过link标签引入外部样式

    <link type="text/css" rel="stylesheet" href="path/style.css" />
    /*style.css*/
    @charset "utf-8";
    .stuff{color:#f90;}
    

    进入正题。

    style属性获取样式值,使用方法:obj.style.attr

    style只能获取元素的内联样式,内部样式和外部样式使用style都获取不到。

    <!DOCTYPE html>
    <html>
    <head>
    <meta charset="UTF-8">
    <title>Document</title>
        <style type="text/css">
            #stuff{300px;}
        </style>
        <link rel="stylesheet" href="a.css">
    </head>
    <body>
        <div id="stuff">Hello world</div>
        <script type="text/javascript">
            var stuff = document.getElementById('stuff');
            //如果只设置外部样式和内嵌样式获取的是空值
            alert(stuff.style.width);//400px
    </script>
    </body>
    </html>
    //外部样式
    @charset "utf-8";
    #stuff{100px;}
    

    currentStyle和getComputedStyle方法既可以获取内联样式,也可以获取外部样式和内嵌样式的值。获取的顺序是内联样式->外部样式->内嵌样式。他们之间的区别是currentStyle只适用于IE浏览器,getComputedStyle适用于Firefox、Opera、Safari、Chrome浏览器。使用方法:

    //currentStyle
    var style = obj.currentStyle['attr']或obj.currentStyle.attr
    //getComputedStyle
    var style = getComputedStyle(obj, pseudoElt)['attr']或getComputedStyle(obj, pseudoElt).attr
    其中,pseudoElt表示如:after, :before之类的伪类元素,如果不用伪类的话设置为null即可。
    
    //为了浏览器的兼容性,可以封装成一个函数使用
    function getStyle(obj, attr){
        if(obj.currentStyle){
            return obj.currentStyle['attr'];
        }else{
            return getComputedStyle(obj, null)['attr'];
        }
    }
    

    getComputedStyle、currentStyle和style的区别是:

    getComputedStyle和currentStyle只能获取属性值,无法设置属性。如果想设置属性值,可是使用ob.style.attr.

    转载请注明出处

    如果你觉得文章不错,可以点一下右下角的推荐

    今天的风有点喧嚣啊

  • 相关阅读:
    用 Web 实现一个简易的音频编辑器
    TypeScript教程
    他的独,殇情沉醉
    重新拎一遍js的正则表达式
    网络流
    Xmind最新的安装与破解教程
    adb的端口号5037被占用的解决方法
    使用Fiddler模拟弱网测试教程
    web的前台、后台、前端、后端
    常见面试笔试题
  • 原文地址:https://www.cnblogs.com/maple0x/p/5551652.html
Copyright © 2011-2022 走看看