关于使用动态样式的信息 - Web API 接口参考 编辑

CSS 对象模型(CSSOM),是 DOM 的一部分,通过暴露一些接口,允许操作很多与 CSS 相关的信息。最初定义在 DOM Level 2 Style 提议中,现在,这些接口形成了一个规范,CSS对象模型(CSSOM),旨在取代它。

在很多情况下,如果可能的话,通过 className 属性来动态操作元素类名确实是最好的方式,因为所有的样式钩子的最终外观都可以在一个样式表中控制。这样写出的 JavaScript 代码也会变得更清晰,因为它不专注与样式相关的细节,而是专注于所创作或者操作的每一部分的整体语义,将精细的样式细节留给样式表。然而实际上也有以一些获取或者操作样式规则有用的情况(无论是对于正样式包还是的那个元素),将在下面进一步详细描述。同样应该注意,同操作单独元素的样式一样,当说到操作样式表的时候,并不是真的操作实际的物理文档,而仅仅是文档的内部表示。

基本样式对象公开了 StylesheetCSSStylesheet 接口。这些接口包括 insertRuleselectorText 以及 parentStyleSheet 等成员,用于获取和操作组成 CSS 样式表的各个规则。

要从 document 中获取 style 对象,可以使用 document.styleSheets 属性,并使用索引来获取某个对象(例如, document.styleSheets[0] 是该文档中的第一个样式表)。

通过 CSSOM 修改样式表

<html>
<head>
<title>Modifying a stylesheet rule with CSSOM</title>
<style type="text/css">
body {
 background-color: red;
}
</style>
<script type="text/javascript">
var stylesheet = document.styleSheets[1];
stylesheet.cssRules[0].style.backgroundColor="blue";
</script>
</head>
<body>
The stylesheet declaration for the body's background color is modified via JavaScript.
</body>
</html>

 DOM CSS Properties List 中给出了 DOM 中 style 属性的可用属性列表。

若要使用 CSS 语法修改文档的样式,可以插入样式规则,或者插入<style> 标签,并将其 innerHTML 属性设置为期望的 CSS。

修改元素样式

 元素的 style 属性(见下面的 DOM 样式对象部分)也可以用于获取和设置元素的样式。然而,该属性只能返回通过内敛方式设置的样式属性(例如 <td style="background-color: lightblue"> 返回 "background-color:lightblue",或者直接针对哪个元素使用  element.style.propertyName, 即使样式表中还有该元素上的其他样式)。

此外,当你在元素上设置某个属性的时候,你会覆盖并擦除掉别处为该元素的这个属性设置的值。以设置 border 属性为例,将覆盖掉在 <head> 部分或者外部样式表设置的该元素的 border 属性。然而这并不会影响元素的其他属性,例如 padding、margin 或 font等。

要修改特定元素的样式,可以将以下示例修改为你想要的样式。

<html>
<head>
<title>simple style example</title>

<script type="text/javascript">

function alterStyle(elem) {
  elem.style.background = 'green';
}

function resetStyle(elemId) {
  elem = document.getElementById(elemId);
  elem.style.background = 'white';
}
</script>

<style type="text/css">
#p1 {
  border: solid blue 2px;
}
</style>
</head>

<body>

<!-- passes a reference to the element's object as parameter 'this'. -->
<p id="p1" onclick="alterStyle(this);">
 Click here to change background color.
</p>

<!-- passes the 'p1' id of another element's style to modify. -->
<button onclick="resetStyle('p1');">Reset background color</button>

</body>
</html>

document.defaultView 对象的 getComputedStyle() 返回某个元素的所有经过计算的样式. 查看Example 6: getComputedStyle 示例章节了解更多使用该方法的信息。.

DOM样式对象

style 对象表示了一个单独的样式声明。不像document.styleSheets 集合中每个单独的样式规则,样式规则是通过 document 对象或者应用改样式的元素来访问的. 它表示特定元素的内联样式。

比这两个属性更重要的是使用 style 对象来给某个元素设置单独的样式属性。

<!DOCTYPE html>
<html>
 <head>
  <title>style Property Example</title>
  <link rel="StyleSheet" href="example.css" type="text/css">
  <script type="text/javascript">
    function stilo() {
      document.getElementById('d').style.color = 'orange';
    }
    function resetStyle() {
      document.getElementById('d').style.color = 'black';
    }
  </script>
 </head>

 <body>
  <div id="d" class="thunder">Thunder</div>
  <button onclick="stilo()">Click here to change text color</button>
  <button onclick="resetStyle()">Reset text color</button>
 </body>
</html>

style的 media 和type 给不给出都可以。

使用 setAttribute 方法

注意,你也可以通过获得元素的引用,然后使用它的 setAttribute 方法,指定CSS属性和值,来改变该元素的样式。

var el = document.getElementById('some-element');
el.setAttribute('style', 'background-color:darkblue;');

但请注意,setAttribute 会移除该元素样式对象中已经定义的其他样式属性。如果上面的 some-element 有一个行内样式属性:style="font-size: 18px",其值将会因为使用了 setAttribute 方法而被移除。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

词条统计

浏览:108 次

字数:8937

最后编辑:6 年前

编辑次数:0 次

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文