日期:2014-05-16  浏览次数:20406 次

js怎么获取css设置的样式?
我的意思是如果这样写

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

js就可以正常获取样式

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

以上代码display得到"none"

但是如果这样,不直接写到标签的属性里

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

再用上面的js代码区获取就不会成功,会返回“”空

所以我想问一下如果第二种情况要获取样式js代码怎么写啊?
JavaScript HTML CSS

------解决方案--------------------
用getComputedStyle与currentStyle获取样式信息

  大家都知道,用document.getElementById(‘element’).style.xxx可以获取元素的样式信息,可是它获取的只是DOM元素style属性里的样式规则,对于通过class属性引用的外部样式表,就拿不到我们要的信息了。

  DOM标准里有个全局方法getComputedStyle,可以获取到当前对象样式规则信息,如: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);