内容简介:引用Window.getComputedStyle()方法返回一个对象,该对象在应用活动样式表并解析这些值可能包含的任何基本计算后报告元素的所有CSS属性的值。 私有的CSS属性值可以通过对象提供的API或通过简单地使用CSS属性名称进行索引来访问。例如:
引用 MND 的说明:
Window.getComputedStyle()方法返回一个对象,该对象在应用活动样式表并解析这些值可能包含的任何基本计算后报告元素的所有CSS属性的值。 私有的CSS属性值可以通过对象提供的API或通过简单地使用CSS属性名称进行索引来访问。
语法
let style = window.getComputedStyle(element, [pseudoElt]);
- element : 用语获取计算样式的Element
- pseudoElt : 指定一个要匹配的伪元素的字符串。必须对普通元素省略(或null)。
例如:
var dom = document.getElementById("test") var style = window.getComputedStyle(dom , ":after") var style = window.getComputedStyle(dom , ":after").content
getComputedStyle与style的区别
我们使用 element.style
也可以获取元素的CSS样式声明对象,但是其与 getComputedStyle
方法还有有一些差异的。
-
只读与可写
-
正如上面提到的
getComputedStyle
方法是只读的,只能获取样式,不能设置;而element.style
能读能写,能屈能伸。
-
正如上面提到的
-
获取的对象范围
-
getComputedStyle
方法获取的是最终应用在元素上的所有CSS属性对象(即使没有CSS代码,也会把默认的祖宗八代都显示出来);而element.style
只能获取元素style
属性中的CSS样式。因此对于一个光秃秃的元素<p>
,getComputedStyle
方法返回对象中length
属性值(如果有)就是190+(据我测试FF:192, IE9:195, Chrome:253, 不同环境结果可能有差异), 而element.style
就是0
。
-
getComputedStyle与defaultView
许多在线的演示代码中, getComputedStyle
是通过 document.defaultView
对象来调用的。大部分情况下,这是不需要的,因为可以直接通过 window
对象调用。但有一种情况,你必需要使用 defaultView
, 那是在firefox3.6上访问子框架内的样式 。
getPropertyValue
getPropertyValue
方法可以获取CSS样式申明对象上的属性值(直接属性名称),例如:
window.getComputedStyle(element, null).getPropertyValue("float");
如果我们不使用 getPropertyValue
方法,直接使用键值访问,其实也是可以的。但是,比如这里的的 float
,如果使用键值访问,则不能直接使用 getComputedStyle(element, null).float
,而应该是 cssFloat
与 styleFloat
,自然需要浏览器判断了,比较折腾!
使用 getPropertyValue
方法不必可以驼峰书写形式(不支持驼峰写法),例如: style.getPropertyValue("border-top-left-radius")
获取变量
例子:
:root{ --testMargin:75px; }
// 读取 var root = getComputedStyle(document.documentElement); var cssVariable = root.getPropertyValue('--testMargin').trim(); console.log(cssVariable); // '75px' // 写入 document.documentElement.style.setProperty('--testMargin', '100px');
CSSStyleDeclaration
概要
CSSStyleDeclaration
表示一个CSS属性键值对的集合。它被用于一些API中:
-
HTMLElement.style
- 用于操作单个元素的样式(); - (TODO: reword) 作为 declaration block 的接口,当规则为 CSSStyleRule 时,由stylesheet中的 style 属性返回 。
-
CSSStyleDeclaration
也是由window.getComputedStyle()
返回的只读接口.
方法
CSSStyleDeclaration.getPropertyPriority() CSSStyleDeclaration.getPropertyValue() CSSStyleDeclaration.item() CSSStyleDeclaration.removeProperty() CSSStyleDeclaration.setProperty() CSSStyleDeclaration.getPropertyCSSValue()
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
CSS3 Solutions
Marco Casario / Apress / 2012-8-13 / GBP 35.50
CSS3 brings a mass of changes, additions, and improvements to CSS across a range of new modules. Web designers and developers now have a whole host of new techniques up their sleeves, from working wit......一起来看看 《CSS3 Solutions》 这本书的介绍吧!