JavaScript访问CSS属性的几种方式介绍


Posted in Javascript onJuly 21, 2014

JavaScript访问CSS属性的方式总体说来有两种:“通过元素访问”、“直接访问样式表”。另外访问样式的时候有一个不可忽略的问题——运行时样式。

1.通过元素访问

既然是要通过元素访问样式表,那么就应该先确定是哪个元素。这是DOM的内容,在此先不多说。获取引用之后就可以通过 “引用.style.要访问的属性” ,来访问某个属性。举个例子,看如下代码。

<pre name="code" class="html"><pre name="code" class="html"><!DOCTYPE html> 
<html> 
<head> 
<meta charset="utf-8"> 
<style> 
#a{ 
height:100px; 
width:100px; 
background-color:red; 
} 
</style> 
</head> 
<body> 
<div id="a"></div> 
</body> 
</html>

当我们想要获取#a的背景色的时候就可以 document.getElementById("a").style.backgroundColor;这样就完成了访问,之后是要返回还是更改属性值那就随你便了。

2.直接访问样式表

直接访问样式表总的来说就是“先找到相应的样式块,然后在该样式块里找相应的样式规则,最后在该样式规则里找相应的样式”。

先说什么是样式块。在代码中,CSS代码会存在于<style></style>标签之间或<link>之中,一个<style></style>或<link>就是一个样式块。在代码中可能从上到下依次排列着多个代码块,我们可以像访问数组元素一样访问样式块。例如我们要访问样式块中的第一个,就可以document.styleSheets[0]

然后说什么是样式规则。先看如下代码

<pre name="code" class="html"><!DOCTYPE html> 
<html> 
<head> 
<meta charset="utf-8"> 
<style> 
#a{ 
height:100px; 
width:100px; 
background-color:red; 
} 
#b{ 
height:100px; 
width:100px; 
background-color:blue; 
} 
</style> 
</head> 
<body> 
<div id="a"></div> 
<div id="b"></div> 
</body> 
</html>

代码中分别规定了#a和#b的样式,#a的样式的集合或#b的集合就是一个样式规则。在这个样式块中,对#a的是第一个样式规则,对#b的是第二个样式规则。我们同样可以像访问数组元素一样访问样式规则。例如我们要访问#b样式规则,就可以document.styleSheets[0].cssRules[1] 当然你可以选择这么写document.styleSheet[0].rules[1]但这种写法不被Firefox支持。

然后我们就可以访问相应的样式了。例如我们要把#b的背景色改成绿色,就可以document.styleSheets[0].cssRules[1].style.backgroundColor="green";

3.运行时样式

看如下代码:

<!DOCTYPE html> 
<html> 
<head> 
<meta charset="utf-8"> 
<style> 
#a{ 
height:100px; 
width:100px; 
color:red; 
} 
#b{ 
height:100px; 
width:100px; 
} 
</style> 
</head> 
<body> 
<div id="a"> 
<div id="b">观察字体颜色</div> 
</div> 
</body> 
</html>

当我们运行alert(document.getElementById("b").style.color);的时候发现弹窗上什么都没输出,但页面的字体颜色明明是红色,为啥呢?这是因为每个元素的style对象属性并不是即时更新的。当我们要弹窗上输出红色的时候就要用运行时样式。window.getComputedStyle(document.getElementById("b"),null).color这样就可以访问到“红色”。访问运行时样式也有另外一种写法document.getElementById("b").currentStyle.color 但这种写法只有IE支持。

Javascript 相关文章推荐
70+漂亮且极具亲和力的导航菜单设计国外网站推荐
Sep 20 Javascript
嵌入式iframe子页面与父页面js通信的方法
Jan 20 Javascript
JavaScript获得url所有参数键值表的方法
Mar 21 Javascript
Node.js 去掉种子(torrent)文件里的邪恶信息
Mar 27 Javascript
JavaScript中指定函数名称的相关方法
Jun 04 Javascript
JavaScript编写点击查看大图的页面半透明遮罩层效果实例
May 09 Javascript
bootstrap是什么_动力节点Java学院整理
Jul 14 Javascript
Node.js爬取豆瓣数据实例分析
Mar 05 Javascript
Layer弹出层动态获取数据的方法
Aug 20 Javascript
JS前端知识点总结之页面加载事件,数组操作,DOM节点操作,循环和分支
Jul 04 Javascript
JS实现audio音频剪裁剪切复制播放与上传(步骤详解)
Jul 28 Javascript
ES6字符串的扩展实例
Dec 21 Javascript
javascript实现的元素拖动函数宿主为浏览器
Jul 21 #Javascript
javascript定义变量时有var和没有var的区别探讨
Jul 21 #Javascript
JQuery中$(document)是什么意思有什么作用
Jul 21 #Javascript
jquery显示隐藏input对象
Jul 21 #Javascript
jquery实现保存已选用户
Jul 21 #Javascript
jquery实现显示已选用户
Jul 21 #Javascript
jquery操作checkbox示例分享
Jul 21 #Javascript
You might like
PHP 采集心得技巧
2009/05/15 PHP
PHP生成不同颜色、不同大小的tag标签函数
2013/09/23 PHP
php计算数组相同值出现次数的代码(array_count_values)
2015/01/20 PHP
微信公众平台开发实现2048游戏的方法
2015/04/15 PHP
php pthreads多线程的安装与使用
2016/01/19 PHP
Jquery Select操作方法集合脚本之家特别版
2010/05/17 Javascript
JavaScript中的作用域链和闭包
2012/06/30 Javascript
Javascript表格翻页效果实现思路及代码
2013/08/23 Javascript
JS实现可直接显示网页代码运行效果的HTML代码预览功能实例
2015/08/06 Javascript
jQuery实现公告新闻自动滚屏效果实例代码
2016/07/14 Javascript
JavaScript纯色二维码变成彩色二维码
2020/07/23 Javascript
ES6学习笔记之map、set与数组、对象的对比
2018/03/01 Javascript
纯JS实现可用于页码更换的飞页特效示例
2018/05/21 Javascript
React 无状态组件(Stateless Component) 与高阶组件
2018/08/14 Javascript
JS栈stack类的实现与使用方法示例
2019/01/31 Javascript
JavaScript中常用的简洁高级技巧总结
2019/03/10 Javascript
[31:00]2014 DOTA2华西杯精英邀请赛5 24 NewBee VS iG
2014/05/25 DOTA
[01:23:24]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Elephant BO3 第三场 2月7日
2021/03/11 DOTA
python3爬取数据至mysql的方法
2018/06/26 Python
Python实现注册、登录小程序功能
2018/09/21 Python
python 实现矩阵填充0的例子
2019/11/29 Python
python爬虫scrapy框架的梨视频案例解析
2021/02/20 Python
关于css中margin的值和垂直外边距重叠问题
2020/10/27 HTML / CSS
基于 HTML5 Canvas实现 的交互式地铁线路图
2018/03/05 HTML / CSS
数控专业推荐信范文
2013/12/02 职场文书
如何写自我鉴定
2014/03/19 职场文书
工地质量标语
2014/06/12 职场文书
师范生求职信
2014/06/14 职场文书
运动会广播稿诗歌版
2014/09/12 职场文书
销售经理岗位职责
2015/01/31 职场文书
单身申明具结书
2015/02/26 职场文书
企业党员岗位承诺书
2015/04/27 职场文书
小学班主任教育随笔
2015/08/15 职场文书
解决numpy数组互换两行及赋值的问题
2021/04/17 Python
python神经网络学习 使用Keras进行回归运算
2022/05/04 Python
SQL Server2019安装的详细步骤实战记录(亲测可用)
2022/06/10 SQL Server