您现在的位置: 爱51代码网 >> 范文 >> 文章正文
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代码怎么写啊?
用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;
var display = document.getElementById("div1");
    style = window.getComputedStyle(display),
    display = style.getPropertyValue('display');
    alert(display);

  • 上一篇文章:

  • 下一篇文章: 没有了
  • 最新文章 热点文章 相关文章
    redhat 2.6 (santigo 5.6) vsftp
    shell如何实现自动填写操作执行下
    linux shell 文件配置sh:color:
    shell script语法一定要加path吗
    SecureCRT如何访问虚拟机vmWare中
    C#如何读取WINDOWS的放大系数
    cximge的图如何存入数据库并提取
    DBGRID控件显示查询结果文本类型
    TChart控件如何把表中右边的系列
    fastreport提示没有找到fr_class
    cximge的图如何存入数据库并提取
    linux下编译faac及faad2提示 rec
    TClientDataSet如何避免多人更新
    如何用delphi代码修改XML节点
    vc++ pvoid *用delphi怎么表达
    GIS用百度行政区域的经纬度直接画
    不小心卸载了.net 4 extend,vs2
    C#byte【】里的数转换成string时
    C#的session取不到值
    java如何判断一个字符串里的数字
    如何获取一个TABLE里所有的i
    jquery如何获取js输出的数据
    preventDefault()如何阻止被
    expression 在chrome下怎么用
    如何检测当前批处理是否以管
    网上邻居出现多个pptv多屏互
    xp系统安装了两个计算机管理
    如何批量重命名去除文件名前
    easyui Tree 的json字符串拼
    datagrid在显示Long类型数据
     



    设为首页 | 加入收藏 | 网站地图 | 友情链接 |