javascript获取元素CSS样式代码示例


Posted in Javascript onNovember 28, 2013

使用css控制页面有4种方式,分别为行内样式(内联样式)、内嵌式、链接式、导入式。

行内样式(内联样式)即写在html标签中的style属性中,如<div style="width:100px;height:100px;"></div>

内嵌样式即写在style标签中,例如<style type="text/css">div{width:100px; height:100px}</style>

链接式即为用link标签引入css文件,例如<link href="test.css" type="text/css" rel="stylesheet" />

导入式即为用import引入css文件,例如@import url("test.css")

如果想用javascript获取一个元素的样式信息,首先想到的应该是元素的style属性。但是元素的style属性仅仅代表了元素的内联样式,如果一个元素的部分样式信息写在内联样式中,一部分写在外部的css文件中,通过style属性是不能获取到元素的完整样式信息的。因此,需要使用元素的计算样式才获取元素的样式信息。

用window对象的getComputedStyle方法来获取一个元素的计算样式,此方法有2个参数,第一个参数为要获取计算样式的元素,第二个参数可以是null、空字符串、伪类(如:before,:after),这两个参数都是必需的。

来个例子

<style type="text/css">

#testDiv{

border:1px solid red;

width: 100px;

height: 100px;

color: red;

}

</style>

<div id="testDiv"></div>

var testDiv = document.getElementById("testDiv");

var computedStyle = window.getComputedStyle(testDiv, "");

var width = computedStyle.width;

//100px

var height = computedStyle.height;

//100px

var color = computedStyle.color;

//rgb(255, 0, 0)
[/code]

注:获取到的颜色属性都是以rgb(#,#,#)格式返回的。

这个时候如果用testDiv.style来获取样式信息,如testDiv.style.width肯定是为空的。

 

getComputedStyle方法在IE8以及更早的版本中没有实现,但是IE中每个元素有自己的currentStyle属性。

so,来个通用的

var testDiv = document.getElementById("testDiv");
var styleInfo = window.getComputedStyle ? window.getComputedStyle(testDiv, "") : testDiv.currentStyle;
var width = styleInfo.width;
//100px;
var height = styleInfo.height;
//100px;
var color = styleInfo.color;
// rgb(255, 0, 0)

 

最后要注意一点,元素的计算样式是只读的,如果想设置元素样式,还得用元素的style属性(这个才是元素style属性的真正用途所在)。

Javascript 相关文章推荐
js动态生成指定行数的表格
Jul 11 Javascript
JavaScript简单实现鼠标拖动选择功能
Mar 06 Javascript
Javascript优化技巧之短路表达式详细介绍
Mar 27 Javascript
jQuery插件实现文字无缝向上滚动效果代码
Feb 25 Javascript
让你一句话理解闭包(简单易懂)
Jun 03 Javascript
jQuery实现checkbox列表的全选、反选功能
Nov 24 Javascript
谈谈Vue.js——vue-resource全攻略
Jan 16 Javascript
jQuery插件zTree实现的基本树与节点获取操作示例
Mar 08 Javascript
jQuery实现导航栏头部菜单项点击后变换颜色的方法
Jul 19 jQuery
JS实现简单的选择题测评系统代码思路详解(demo)
Sep 03 Javascript
关于vue的语法规则检测报错问题的解决
May 21 Javascript
JS实现快递单打印功能【推荐】
Jun 21 Javascript
浅析JavaScript中的CSS属性及命名规范
Nov 28 #Javascript
JavaScript中的连字符详解
Nov 28 #Javascript
Google (Local) Search API的简单使用介绍
Nov 28 #Javascript
jquery实现弹出窗口效果的实例代码
Nov 28 #Javascript
asm.js使用示例代码
Nov 28 #Javascript
jquery实现动态菜单的实例代码
Nov 28 #Javascript
JavaScript中的常见问题解决方法(乱码,IE缓存,代理)
Nov 28 #Javascript
You might like
调频问题解答
2021/03/01 无线电
深入PHP nl2br()格式化输出的详解
2013/06/05 PHP
几个比较实用的JavaScript 测试及效验工具
2010/04/18 Javascript
关于js日期转化为毫秒数“节省20%的效率和和节省9个字符“问题
2012/03/01 Javascript
javascript中自定义对象的属性方法分享
2013/07/12 Javascript
用JS将搜索的关键字高亮显示实现代码
2013/11/08 Javascript
jQuery实现流动虚线框的方法
2015/01/29 Javascript
JS+CSS实现仿新浪微博搜索框的方法
2015/02/24 Javascript
JavaScript从数组中删除指定值元素的方法
2015/03/18 Javascript
JavaScript实现俄罗斯方块游戏过程分析及源码分享
2015/03/23 Javascript
JQuery显示、隐藏div的几种方法简明总结
2015/04/16 Javascript
纯javascript代码实现计算器功能(三种方法)
2015/09/07 Javascript
JS+CSS实现简易实用的滑动门菜单效果
2015/09/18 Javascript
AngularJS 执行流程详细介绍
2016/08/18 Javascript
一文让你彻底搞清楚javascript中的require、import与export
2017/09/24 Javascript
浅谈Webpack打包优化技巧
2018/06/12 Javascript
jQuery无冲突模式详解
2019/01/17 jQuery
如何在vue中使用kindeditor富文本编辑器
2020/12/19 Vue.js
python在windows下实现备份程序实例
2014/07/04 Python
Python中的MongoDB基本操作:连接、查询实例
2015/02/13 Python
PyQt5 控件字体样式等设置的实现
2020/05/13 Python
解决Python Matplotlib绘图数据点位置错乱问题
2020/05/16 Python
使用opencv中匹配点对的坐标提取方式
2020/06/04 Python
keras K.function获取某层的输出操作
2020/06/29 Python
基于selenium及python实现下拉选项定位select
2020/07/22 Python
利用Python实现朋友圈中的九宫格图片效果
2020/09/03 Python
python实现图片,视频人脸识别(dlib版)
2020/11/18 Python
一款html5 canvas实现的图片玻璃碎片特效
2014/09/11 HTML / CSS
皇马官方商城:Real Madrid Store
2016/09/02 全球购物
荷兰的时尚市场:To Be Dressed
2019/05/06 全球购物
团日活动总结
2014/04/28 职场文书
关工委先进个人事迹材料
2014/05/23 职场文书
2014乡镇党政班子四风问题思想汇报
2014/09/14 职场文书
党的群众路线教育实践活动个人对照检查材料(企业)
2014/11/05 职场文书
开学典礼观后感
2015/06/15 职场文书
Win11怎么启动任务管理器?Win11启动任务管理器的几种方法
2021/11/23 数码科技