JavaScript CSS修改学习第三章 修改样式表


Posted in Javascript onFebruary 19, 2010

请注意代码和传统的DHTML的区别。在DHTML你通过直接修改页面上的特定元素来改变样式,而这里的代码修改的是样式表。
在这里查看W3C DOM-CSS的兼容性列表。
定义
一个页面总是包含一个或者几个样式表,一个样式表里面包含一条或者几条规则,一条规则里有详细的样式声明。这个页面的样式表如下:

<link rel="stylesheet" href="../quirksmode.css"> 
<style> 
<!-- 
@import url("test.css"); 
p,h2,h3 { 
    padding-right: 10px; 
} 
pre.test + * { 
    margin-right: 20%; 
} 
pre.test { 
    background-color: #ffffff; 
} 
--> 
</style>

我们的目的是修改pre.test的白色背景为#EEF0F5。
样式表
所有外链或者内嵌的样式表都能通过document.styleSheets数组访问。quirksmode.css,这个网站的通用样式表保存在document.styleSheets[0]里。上面这段特别的样式表段就保存在document.styleSheets[1]。我们就在这段代码上进行测试。
cssRules[]和rules[]
一条规则就是一个或者多个元素的一组声明。这里有两种访问规则的方法。W3C坚持使用cssRules[],而微软坚持rules[]。两种方法都是用索引数字,第一条规则就是(css)Rules[0],第二条就是(css)Rules[1]等等。
var theRules = new Array(); 
if (document.styleSheets[1].cssRules) 
    theRules = document.styleSheets[1].cssRules 
else if (document.styleSheets[1].rules) 
    theRules = document.styleSheets[1].rules

现在theRules就包含了所有的样式规则。规则的数目
这是样式表:
@import url("test.css"); 
p,h2,h3 { 
    padding-right: 10px; 
} 
pre.test + * { 
    margin-right: 20%; 
} 
pre.test { 
    background-color: #ffffff; 
}

在你看来可能是4条规则:@import 然后是p,h2,h3,接着pre.test + *,最后是pre.test。然而浏览器可不这么看。
Safari看见的是4条规则:
0、undefined
1、P
2、PRE.test[CLASSS~="test"]+*
3、PRE.test[CLASSS~="test"]
注意大写
IE7beta3看见了5条:
0、P
1、H2
2、H3
3、PRE.test + *
4、PRE.test
注意大写
Mac IE也看见5条:
0、P
1、H2
2、H3
3、PRE.test * (注意没有+号)
4、PRE.test
注意大写
Mozilla和Opera 9看见4条:
0、undefined
1、p,h2,h3
2、pre.test + *
3、pre.test
注意小写
非常棒的混乱!
1、IE认为p,h2,h3是三条而不是一条规则,而Safari则只取p。知道现在我才知道这是一种不正确的写法。
2、Mac IE把选择器改成了pre.test *,这样含义就非常不一样了。非常严重的问题。
3、除了Safari给pre.test添加了不必要的表达式以外,这个是支持最好的了。
所以要访问pre.test在Safari和Mozilla里需要cssRules[3],而IE是rules[4],早期的Mozilla是cssRules[5]。很可爱,不是么?
没有关键字
所以如果使用索引值的话问题就非常严重。我们希望能这样访问:
document.styleSheets[1].cssRules['PRE.test']这样我就能访问pre的样式表规则了。但是W3C或者其他浏览器貌似不需要这样的访问样式表的方法。但是所有的文档在这个问题上都保持沉默。
这个失败意味着你基本上没法访问规则了。
样式声明
假设我们已经访问了一条规则。现在需要改变其中一条声明。表达式如下:
rule.style.color = '#0000cc';

W3C的方法是:
rule.style.setProperty('color','#00cc00',null);

因为style.color简单的多,所以我不想用这个seProperty()。
例子
打算改变pre的颜色,代码如下:
为了保证能用,我把pre的规则写在最后一条。很丑,但是这是唯一的办法:
function changeIt() { 
    if (!document.styleSheets) return; 
    var theRules = new Array(); 
    if (document.styleSheets[1].cssRules) 
        theRules = document.styleSheets[1].cssRules 
    else if (document.styleSheets[1].rules) 
        theRules = document.styleSheets[1].rules 
    else return; 
    theRules[theRules.length-1].style.backgroundColor = '#EEF0F5'; 
}

翻译地址:http://www.quirksmode.org/dom/changess.html
转载请保留以下信息
作者:北玉(tw:@rehawk)
Javascript 相关文章推荐
jQuery 插件 将this下的div轮番显示
Apr 09 Javascript
基于jQuery的可以控制左右滚动及自动滚动效果的代码
Jul 25 Javascript
jquery将一个表单序列化为一个对象的方法
Dec 02 Javascript
window.open()实现post传递参数
Mar 12 Javascript
JavaScript动态创建form表单并提交的实现方法
Dec 10 Javascript
AngularJS入门教程之AngularJS 模板
Aug 18 Javascript
Javascript将字符串日期格式化为yyyy-mm-dd的方法
Oct 27 Javascript
ReactJS实现表单的单选多选和反选的示例
Oct 13 Javascript
JavaScript 中的12种循环遍历方法【总结】
May 31 Javascript
在Vue中获取组件声明时的name属性方法
Sep 12 Javascript
JavaScript进制转换实现方法解析
Jan 18 Javascript
vue element-ui中table合计指定列求和实例
Nov 02 Javascript
JavaScript CSS修改学习第二章 样式
Feb 19 #Javascript
JavaScript CSS修改学习第一章 查找位置
Feb 19 #Javascript
JavaScript DOM 学习第九章 选取范围的介绍
Feb 19 #Javascript
JavaScript DOM学习第八章 表单错误提示
Feb 19 #Javascript
JavaScript DOM 学习第七章 表单的扩展
Feb 19 #Javascript
JavaScript DOM学习第六章 表单实例
Feb 19 #Javascript
JavaScript DOM 学习第五章 表单简介
Feb 19 #Javascript
You might like
php文件上传的简单实例
2013/10/19 PHP
两千行代码的PHP学习笔记汇总
2014/10/05 PHP
PHP设计模式之迭代器模式
2016/06/17 PHP
jQuery Ajax之load()方法
2009/10/12 Javascript
高效的表格行背景隔行变色及选定高亮的JS代码
2010/12/04 Javascript
javascript break指定标签打破多层循环示例
2014/01/20 Javascript
jquery自定义滚动条插件示例分享
2014/02/21 Javascript
详解js中构造流程图的核心技术JsPlumb
2015/12/08 Javascript
基于JavaScript实现高德地图和百度地图提取行政区边界经纬度坐标
2016/01/22 Javascript
jquery根据td给相同tr下其他td赋值的实现方法
2016/10/05 Javascript
8 行 Node.js 代码实现代理服务器
2016/12/05 Javascript
Jquery把获取到的input值转换成json
2017/05/15 jQuery
微信小程序自定义组件
2017/08/16 Javascript
angular json对象push到数组中的方法
2018/02/27 Javascript
理解 JavaScript EventEmitter
2018/03/29 Javascript
深入浅析Vue.js计算属性和侦听器
2018/05/05 Javascript
mockjs+vue页面直接展示数据的方法
2018/12/19 Javascript
解决layui弹框失效的问题
2019/09/09 Javascript
javascript实现前端分页效果
2020/06/24 Javascript
详解Python中expandtabs()方法的使用
2015/05/18 Python
详解Python的Twisted框架中reactor事件管理器的用法
2016/05/25 Python
django最快程序开发流程详解
2019/07/19 Python
python为QT程序添加图标的方法详解
2020/03/09 Python
pyinstaller打包成无控制台程序时运行出错(与popen冲突的解决方法)
2020/04/15 Python
Python JSON常用编解码方法代码实例
2020/09/05 Python
python 可视化库PyG2Plot的使用
2021/01/21 Python
西班牙拥有最佳品牌的动物商店:Animalear.com
2018/01/05 全球购物
《路旁的橡树》教学反思
2014/04/07 职场文书
民主生活会对照检查材料思想汇报
2014/09/27 职场文书
电子银行业务授权委托书
2014/10/10 职场文书
安全保证书怎么写
2015/02/28 职场文书
社区国庆节活动总结
2015/03/23 职场文书
2015年学校食堂工作总结
2015/04/22 职场文书
公司庆典主持词
2015/07/04 职场文书
社区低保工作总结2015
2015/07/23 职场文书
2015年清剿火患专项行动工作总结
2015/07/27 职场文书