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 相关文章推荐
javascript 匿名函数的理解(透彻版)
Jan 28 Javascript
第二次聊一聊JS require.js模块化工具的基础知识
Apr 17 Javascript
jQGrid动态填充select下拉框的选项值(动态填充)
Nov 28 Javascript
基于HTML5+JS实现本地图片裁剪并上传功能
Mar 24 Javascript
vue.js父组件使用外部对象的方法示例
Apr 25 Javascript
微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)
May 11 Javascript
MvcPager分页控件 适用于Bootstrap
Jun 03 Javascript
深入理解基于vue-cli的vuex配置
Jul 24 Javascript
Vue实现PopupWindow组件详解
Apr 28 Javascript
Vue 实现树形视图数据功能
May 07 Javascript
微信小程序搭建自己的Https服务器
May 02 Javascript
判断“命令按钮”是否被鼠标单击详解
Jul 31 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数组(array)输出的三种形式详解
2013/06/05 PHP
PHP编程开发怎么提高编程效率 提高PHP编程技术
2015/11/09 PHP
服务器安全设置的几个注册表设置
2007/07/28 Javascript
javascript js cookie的存储,获取和删除
2007/12/29 Javascript
不懂JavaScript应该怎样学
2008/04/16 Javascript
JS定时器实例
2013/04/17 Javascript
Dom 学习总结以及实例的使用介绍
2013/04/24 Javascript
js history对象简单实现返回和前进
2013/10/30 Javascript
nodejs npm包管理的配置方法及常用命令介绍
2014/06/05 NodeJs
node.js中的fs.lchmod方法使用说明
2014/12/16 Javascript
JavaScript实现信用卡校验方法
2015/04/07 Javascript
js简单判断移动端系统的方法
2016/02/25 Javascript
javascript ASCII和Hex互转的实现方法
2016/12/27 Javascript
如何将 jQuery 从你的 Bootstrap 项目中移除(取而代之使用Vue.js)
2017/07/17 jQuery
微信小程序 POST请求的实例详解
2017/09/29 Javascript
纯html+css+javascript实现楼层跳跃式的页面布局(实例代码)
2017/10/25 Javascript
推荐10款扩展Web表单的JS插件
2017/12/25 Javascript
vue项目打包后上传至GitHub并实现github-pages的预览
2019/05/06 Javascript
Vue.js轮播图走马灯代码实例(全)
2019/05/08 Javascript
Vue2.4+新增属性.sync、$attrs、$listeners的具体使用
2020/03/08 Javascript
[59:00]OG vs TNC 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
pytorch cnn 识别手写的字实现自建图片数据
2018/05/20 Python
python字典一键多值实例代码分享
2019/06/14 Python
django数据关系一对多、多对多模型、自关联的建立
2019/07/24 Python
django rest framework serializer返回时间自动格式化方法
2020/03/31 Python
Python学习之路安装pycharm的教程详解
2020/06/17 Python
python 实现音频叠加的示例
2020/10/29 Python
HTML5之WebGL 3D概述(上)—WebGL原生开发开启网页3D渲染新时代
2013/01/31 HTML / CSS
草莓网美国官网:Strawberrynet USA
2016/12/11 全球购物
杭州时比特电子有限公司SQL
2013/08/22 面试题
不同浏览器创建XMLHttpRequest方法有什么不同
2014/11/17 面试题
绿色家庭事迹材料
2014/05/01 职场文书
大学学生个人总结
2015/02/15 职场文书
企业党员岗位承诺书
2015/04/27 职场文书
干部培训工作总结2015
2015/05/25 职场文书
会议主持人开场白台词
2015/05/28 职场文书