编程爱好者之家

js怎么获取css设置的样式?

2018-02-24 15:40:28 202

我们大家都知道

<div id="div1" style="display:none;"></div>

这样的我们获取的方式是

var display = document.getElementById("div1").style.display;

但是如果是下面的呢我们就获取不到了

<style>
.hide {
    display:none;
}
</style>
<div id="div1" class="hide"></div>

那么我们就要用到js的两个方法了 getComputedStyle与currentStyle获取样式信息

getComputedStyle(obj,null).paddingLeft,就能获取到对象的左内边距。但是事情还没完,万恶的IE不支持此方法,它有自己的一个实现方式,那就是currentStyle,不同于全局方法getComputedStyle,它是作为DOM元素属性存在的,如:obj.currentStyle.paddingLeft,在IE中就获取到对象的左内边距了,兼容性的写法如下:

return window.getComputedStyle ? window.getComputedStyle(obj,null).paddingLeft : obj.currentStyle.paddingLeft;

这样,就能在IE及FF中返回对象的当前样式信息了。

特别注意一点:如果要获取当前对象的颜色信息,IE返回的是16进制的’#ffffff’


所以最终写法如下

var display = document.getElementById("div1");
style = window.getComputedStyle(display),
display = style.getPropertyValue('display');
alert(display);


同类文章