不论什么支持style 特性的元素在 ,在其DOM 节点 对象中都有一个 style 属性与之相应。 这个style 对象是 CSSStyleDeclaration类型的实例,包括着html style特性的所有样式信息。但不包括 外部样式或者 内嵌样式层叠而来的样式。javascript
在style特性中。提定的不论什么css属性,都将表现为这个style 对象的属性。对于使用短划线的的属性名。必须转化为驼峰大写和小写形式,多数状况下都可以这样转换。css
也有例外, float 是javascript keyword,不能直接转换,在ie中 转换为 styleFloat,在其余浏览器中,转换为 cssFloat.html
假设元素没有设置style属于,哪么style会有一些默认的属性。java
1. dom2 来style对象定义了一些属性与方法浏览器
2. 计算样式: “DOM2 级样式”加强了document.defaultView。提供了 getComputedStyle()方法。dom
这种方法接受两个參数:要取得计算样式的元素和一个伪元素字符串(好比":after")。post
假设不需要伪元素信息,第二个參数可以是null。getComputedStyle()方法返回一个CSSStyleDeclaration 对象(与style 属性的类型一样)。当中包括当前元素的所有计算的样式。htm
(IE 中 没有 getComputedStyle()方法,但是在IE中,每个有style属性的元素 都有一个 currentStyle 属性, 它是CSSStyleDeclaration 类型的实例)
对象
边框属性可能会也可能不会返回样式表中实际的border 规则(Opera 会返回,但其它浏览器不会)。ip
存在这个区别的缘由是不一样浏览器解释综合(rollup)属性(如border)的方式不一样,
因为设置这样的属性实际上会涉及很是多其它属性。
在设置border 时。 其实是设置了四个边的边框宽度、颜色、样式属性( border-left-width 、border-top-color 、border-bottom-style 。 等等)。
所以, 即便computedStyle.border 不会在所有浏览器中都返回值,但computedStyle.borderLeftWidth 会返回值。