HTML中定义的样式一共有三种方式:
1. 外部样式表,使用<link>元素导入外部的样式表,样式表都是.css类型的文件;
2. 嵌入样式,使用<style>在HMTL文档中定义的样式;
3. 元素特定样式:即在某个特定标签中style属性定义的样式;
元素的style属性
JavaScript为每个元素提供了一个style属性,让我们可以方便的用编程的方式控制样式。这个style对应的是元素特定样式中的style属性,比如有一个<div id="myDiv" style="border: 4px solid green; width: 100px;"></div>标签元素,JavaScript中的style属性就是对应标签中的style属性。我们可以这样使用:
var div = document.getElementById("myDiv");
div.style.width = "200px"; // 可读写,修改宽度之后,浏览器会马上呈现变化(建议最好要使用px之类的度量单位,否则浏览器可能忽略)
几乎素所有的CSS样式都可以用style进行访问和设置,而且使用这些属性有一些通用的规则:
CSS属性 JavaScript属性
color style.color
font-family style.fontFamily
如果CSS中的属性是带有-符号的,就去掉它,然后变成驼峰的拼写方式就变成了JavaScript的属性。但是有一个例外,就是float的JavaScript属性是cssFloat,IE则是styleFloat。在DOM2级的样式中还为style属性定义了一些新的属性和方法,下面列出一些比较有用的:
cssText:返回整个style中定义的CSS样式字符串,上面的例子就是:"border: 4px solid green; width: 100px;"。如果给它赋值就会重写整个style样式;
length:CSS样式的数量,一组键值对算一个;
getPropertyValue(cssName):返回参数指定的css属性名对应的值;
removeProperty(cssName):删除参数指定的css属性;
item(index):返回索引对应的css属性的名字;
计算样式
上面提到的style属性只会针对某个特定的元素进行样式设置。如果某个元素还引入了外部样式表或者嵌入样式,元素可能会使用class属性导入一些样式,也可能有一些全局的样式,即为div或者body一类标签所设置的样式。对于这么多样式,浏览器会按照一定的方式进行层叠计算,然后得出最后的样式,再应用在元素上。计算的步骤如下:
1. 先计算全局的样式,即那些为某一类标签所设定的样式;
2. 然后计算class属性中设定的样式,如果有部分CSS属性的样式值和第一步骤的样式值重叠,就忽略上一个步骤的样式,应用当前的样式;如果class属性中引用了多个样式,那么从左到右依次计算,按照后面的样式会覆盖前面的样式为原则;
3. 最后再计算style属性中的样式,也会按照后面的样式覆盖前面的样式为原则;
重叠到最后得出的样式就叫计算样式,DOM2级中定义了一个属性叫document.defaultView,这个属性有一个方法叫getComputedStyle(元素)可以得出指定元素的最后的计算样式。用法如下:
var computedStyle = document.defaultView.getComputedStyle( myDiv );
alert( computedStyle.width );
取出的计算样式都是只读的,无法直接修改。对于IE并不支持这个属性,但是有一个替代属性:currentStyle。这个属性来自每个元素自身,所以兼容性的写法就是:
function getComputedStyle( element ) {
if ( typeof document.defaultView.getComputedStyle === "function" ) {
return document.defaultView.getComputedStyle( element );
}
else {
return element.currentStyle;
}
}
操作样式表
无论是用<link>标签引入外部样式表,还是使用<style>标签创建的嵌入样式表,都属于StyleSheet类型,我们可以通过编程的方式访问这些样式表对象。
DOM2级提高了一个document.styleSheets的集合对象,里面保存了当前文档使用的所有样式表对象,我们只需要用[]加索引就可以像数组一样取出某个特定的样式表对象。除此之外,我们也可以通过<link>和<style>标签获取对应的样式表对象,IE使用styleSheet属性,其他浏览器使用sheet属性:兼容性的代码如下:
function getCSSStyleSheet( sheetElement ) {
return sheetElement.sheet || sheetElement.styleSheet;
}
var link = document.getElementsByTagName("link")[0];
var sheet = getCSSStyleSheet( link ); // 取出样式表对象
样式表对象有很多使用的属性和方法:
disabled: 可读写,默认为false表示不禁用该样式表,设置成true就会立即禁用该样式表,浏览器也会重新计算样式;
href: 引入样式表的url,如果是嵌入样式,则为null;
ownerNode:指向引用该样式表的节点,可能是<link>或<style>;
type:类型,样式表则是“text/css”;
cssRules:样式表中的规则,IE用rules属性代替,可以用[index]的方式取出其中的某条规则;
deleteRule(index):删除样式表中指定i的index的那条规则,IE中用removeRule代替;
insertRule(rule, index):在样式表中指定位置插入一条规则,IE中用addRule代替;
关于CSS中的规则,其实就像如下的一个样式:
div {
width: 100px;
height: 100px;
}
这就是某个样式表中的一条规则,它属于CSSStyleRule类型的一个对象,所以它也有自己的属性和方法,常用的有:
cssText:返回这个规则的文本值,“div { width: 100px; height: 100px; }”;
parentStyleSheet:引用当前样式表;
selectorText:选择器的文本,如div;
style:规则中所有样式,如style.width,可以设置,注意会影响所有使用该规则的元素;
type:样式表始终是1,IE不支持;
例子:
var sheet = document.styleSheets[0];
sheet.insertRule("div { border: 20px solid yellow;}", 1 ); // 插入的位置很重要,如果插入的样式被后面的样式替换,就不会起作用
// sheet.addRule("div", "border: 20px solid yellow", 1); IE的方式
sheet.deleteRule(1); // 删除索引为1的规则
// sheet.removeRule(1); // IE的方式