大前端

原生js获取css样式

2017-03-13  本文已影响203人  天問_专注于大前端技术

在前端开发过程中往往需要动态的编辑、修改一个UI的样式,这必然涉及到style的获取与设置。
一般都说有图有真相,而我们程序猿当然是用demo来说明一切,下面就根据一则具体事例探讨原生js获取css样式的方法。

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>test</title>
    <style>
        #div1{
            width: 200px;
            background:#00f;
            border: 1px solid #000;
        }
    </style>
</head>
<body>
<div id="div1" style="height:100px;"></div>
<script>
    window.onload = function() {
        var oDiv = document.getElementById('div1');
        // div的width
        console.log(oDiv.style.width);
        // div的height
        console.log(oDiv.style.height);
    }
</script>
</body>
</html>

经过浏览器运行之后,在console控制台很明显有输出。

很多人不明白是怎么回事,想要获取的width怎么是空白。
原来是因为直接用oDiv.style方法只能获取元素的内联样式,对于内部样式外联样式,这种方法则不能取得。
因此要另寻出路,众所周知,IE浏览器总是别具一格,格外奇葩,所以这里还得解决兼容性问题:

var oDiv = document.getElementById('div');
var styles = oDiv.currentStyle;
styles.width;
var oDiv = document.getElementById('div');
var style = window.getComputedStyle(oDiv, null);
styles.width;
function getStyle(obj,attr){
    return obj.currentStyle?obj.currentStyle[attr]:getComputedStyle(obj)[attr];
}

提示:

参考博文:

上一篇 下一篇

猜你喜欢

热点阅读