JS获取CSS样式(style/getComputedStyle/currentStyle)


Posted in Javascript onJanuary 19, 2016

CSS的样式分为三类:
内嵌样式:是写在Tag里面的,内嵌样式只对所有的Tag有效。
内部样式:是写在HTML的里面的,内部样式只对所在的网页有效。
外部样式表:如果很多网页需要用到同样的样式(Styles),将样式(Styles)写在一个以.css为后缀的CSS文件里,然后在每个需要用到这 些样式(Styles)的网页里引用这个CSS文件。

getComputedStyle是一个可以获取当前元素所有最终使用的CSS属性值。返回的是一个CSS样式对象([object CSSStyleDeclaration])
currentStyle是IE浏览器的一个属性,返回的是CSS样式对象

element指JS获取的DOM对象
element.style //只能获取内嵌样式
element.currentStyle //IE浏览器获取非内嵌样式
window.getComputedStyle(element,伪类) //非IE浏览器获取非内嵌样式
document.defaultView.getComputedStyle(element,伪类)//非IE浏览器获取非内嵌样式
注:Gecko 2.0 (Firefox 4 / Thunderbird 3.3 / SeaMonkey 2.1) 之前,第二个参数“伪类”是必需的(如果不是伪类,设置为null),现在可以省略这个参数。

下面的html中包含两种css样式,id为tag的div是内嵌样式,而id为test的div样式为内部样式.

<!doctype html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <meta name="Generator" content="EditPlus®">
    <meta name="Author" content="Yvette Lau">
    <meta name="Keywords" content="关键字">
    <meta name="Description" content="描述">
    <title>Document</title>
    <style>
      #test{
        width:500px;
        height:300px;
        background-color:#CCC;
        float:left;
      }
    </style>
  </head>
  <body>
    <div id = "test"></div>
    <div id = "tag" style = "width:500px; height:300px;background-color:pink;"></div>
  </body>
</html>

JS部分

<script type = "text/javascript">
  window.onload = function(){
    var test = document.getElementById("test");
    var tag = document.getElementById("tag");

    //CSS样式对象:CSS2Properties{},CSSStyleDeclaration
    console.log(test.style); //火狐返回空对象CSS2Properties{},谷歌返回空对象CSSStyleDeclaration{} 
    console.log(tag.style); //返回CSS2Properties{width:"500px",height:"300px",background-color:"pink"}
    //element.style获取的是内嵌式的style,如果不是内嵌式,则是一个空对象

    console.log(tag.style.backgroundColor);//pink
    console.log(tag.style['background-color']);//pink
    //获取类似background-color,border-radius,padding-left类似样式的两种写法啊

    console.log(test.currentStyle) //火狐和谷歌为Undefined,IE返回CSS对象
    console.log(window.getComputedStyle(test,null))//谷歌返回CSSStyleDeclaration{……} ,火狐返回CSS2Properties{……}
    console.log(window.getComputedStyle(test))
    //效果同上,但是在Gecko 2.0 (Firefox 4/Thunderbird 3.3/SeaMonkey 2.1) 之前,第二个参数“伪类”是必需的(如果不是伪类,设置为null)

    console.log(test.currentStyle.width);//500px(IE)
    console.log(window.getComputedStyle(test).width); //500px;
    console.log(window.getComputedStyle(test)['width']);//500px;
    //document.defaultView.getComputedStyle(element,null)[attr]/window.getComputedStyle(element,null)[attr]   
  }
</script>

以上的例子仅是验证前面的论述是否正确。

为了简单,我们也可以对获取样式做一个简单的封装。

function getStyle(element, attr){
      if(element.currentStyle){
        return element.currentStyle[attr];
      }else{
        return window.getComputedStyle(element,null)[attr];
      }
    }
    console.log(getStyle(test,"cssFloat"));//left
    console.log(getStyle(test,"float"));  //left,早前FF和chrome需要使用cssFloat,不过现在已经不必
    console.log(getStyle(test,"stylefloat"));//火狐和谷歌都是undefined
    console.log(getStyle(test,"styleFloat")); //IE9以下必须使用styleFloat,IE9及以上,支持styleFloat和cssFloat

    console.log(window.getComputedStyle(test).getPropertyValue("float"))

对应float样式,IE中使用的是styleFloat,而早前的FF和chrome使用的是cssFloat,现在FF和Chrome已经支持float,还有一些其他的属性,不再一一列出,为了不去记忆这些差异点,我们引出两个访问CSS样式对象的方法:
getPropertyValue方法和getAttribute方法

IE9及其它浏览器(getPropertyValue)
window.getComputedStyle(element, null).getPropertyValue(“float”);
element.currentStyle.getPropertyValue(“float”);
getPropertyValue不支持驼峰写法。(兼容IE9及以上,FF,Chrom,Safari,Opera)
如:window.getComputedStyle(element,null).getPropertyValue(“background-color”);

对于IE6~8,需要使用getAttribute方法,用于访问CSS样式对象的属性

element.currentStyle.getAttribute(“float”);//不再需要写成styleFloat
element.currentStyle.getAttribute(“backgroundColor”);//属性名需要写成驼峰写法,否则IE6不支持,如果无视IE6,可以写成”background-color”

以上就是本文的全部内容,希望对大家的学习有所帮助,轻松使用JS获取CSS样式。

Javascript 相关文章推荐
offsetParent 算法分析
Apr 05 Javascript
前端开发必须知道的JS之原型和继承
Jul 06 Javascript
jQuery制作仿腾讯web qq用户体验桌面
Aug 20 Javascript
js 距离某一时间点时间是多少实现代码
Oct 14 Javascript
js获取url中&quot;?&quot;后面的字串方法
May 15 Javascript
Bootstrap3 内联单选和多选框
Dec 29 Javascript
完美解决spring websocket自动断开连接再创建引发的问题
Mar 02 Javascript
js表单序列化判断空值的实例
Sep 22 Javascript
vuejs+element UI点击编辑表格某一行时获取内容填入表单的示例
Oct 31 Javascript
微信小程序实现判断是分享到群还是个人功能示例
May 03 Javascript
javascript定时器的简单应用示例【控制方块移动】
Jun 17 Javascript
vscode调试node.js的实现方法
Mar 22 Javascript
详解javascript实现自定义事件
Jan 19 #Javascript
JS拖拽组件学习使用
Jan 19 #Javascript
理解JS绑定事件
Jan 19 #Javascript
AngularJS模块学习之Anchor Scroll
Jan 19 #Javascript
jQuery unbind()方法实例详解
Jan 19 #Javascript
jQuery绑定事件监听bind和移除事件监听unbind用法实例详解
Jan 19 #Javascript
详解JavaScript对象序列化
Jan 19 #Javascript
You might like
PHP CodeBase:将时间显示为&quot;刚刚&quot;&quot;n分钟/小时前&quot;的方法详解
2013/06/06 PHP
PHP英文字母大小写转换函数小结
2014/05/03 PHP
PHP实现获取毫秒时间戳的方法【使用microtime()函数】
2019/03/01 PHP
php 根据URL下载远程图片、压缩包、pdf等文件到本地
2019/07/26 PHP
JQuery 学习笔记01 JQuery初接触
2010/05/06 Javascript
javascript 触发HTML元素绑定的函数
2010/09/11 Javascript
jquery 鼠标滑动显示详情应用示例
2014/01/24 Javascript
AngularJS基础知识笔记之表格
2015/05/10 Javascript
jquery对复选框(checkbox)的操作汇总
2016/01/13 Javascript
jQuery fancybox在ie浏览器下无法显示关闭按钮的解决办法
2016/02/19 Javascript
react-router JS 控制路由跳转实例
2017/06/15 Javascript
详谈构造函数加括号与不加括号的区别
2017/10/26 Javascript
js实现轮播图效果 z-index实现轮播图
2020/01/17 Javascript
Vue表单控件数据绑定方法详解
2020/02/05 Javascript
python中查找excel某一列的重复数据 剔除之后打印
2013/02/10 Python
在Python的Bottle框架中使用微信API的示例
2015/04/23 Python
Python多线程爬虫简单示例
2016/03/04 Python
python实现决策树
2017/12/21 Python
基于python实现在excel中读取与生成随机数写入excel中
2018/01/04 Python
浅谈python之新式类
2018/08/12 Python
在Python中分别打印列表中的每一个元素方法
2018/11/07 Python
python Tkinter版学生管理系统
2019/02/20 Python
新手如何发布Python项目开源包过程详解
2019/07/11 Python
python图片指定区域替换img.paste函数的使用
2020/04/09 Python
python实现读取类别频数数据画水平条形图案例
2020/04/24 Python
python进度条显示-tqmd模块的实现示例
2020/08/23 Python
css3实现的下拉菜单效果示例
2014/01/22 HTML / CSS
HTML5 File API改善网页上传功能
2009/08/19 HTML / CSS
AMAVII眼镜官网:时尚和设计师太阳镜
2019/05/05 全球购物
化工机械应届生求职信
2013/11/04 职场文书
工程管理专业毕业生自荐信
2014/01/24 职场文书
2015年劳动部工作总结
2015/05/23 职场文书
赞美教师的句子
2019/09/02 职场文书
go语言使用Casbin实现角色的权限控制
2021/06/26 Golang
浅谈redis整数集为什么不能降级
2021/07/25 Redis
Python OpenCV实现图像模板匹配详解
2022/04/07 Python