CSSPageRule

Baseline Widely available *

This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2015.

* Some parts of this feature may have varying levels of support.

CSSPageRule 表示一个单独的 CSS @page 规则。

CSSRule CSSGroupingRule CSSPageRule

实例属性

继承自其父接口 CSSGroupingRuleCSSRule 的属性。

CSSPageRule.selectorText

表示与该 at 规则关联的页面选择器的文本。

CSSPageRule.style 只读

返回与该 at 规则关联的声明块

实例方法

继承自其父接口 CSSGroupingRuleCSSRule 的方法。

示例

筛选页面规则

这个示例展示了如何找到文档加载的 @page 规则对应的 CSSPageRule 对象。

CSS

下面我们使用 @page 规则定义页面样式。

css
@page {
  margin: 1cm;
}

JavaScript

该代码遍历文档中的所有样式表,并遍历每个样式表中的所有 cssRules,记录样式表的索引、规则数量以及每个规则对象的类型。然后,我们通过规则的类型检测 CSSPageRule 对象(对于这些信息不做任何处理)。

js
for (
  let sheetCount = 0;
  sheetCount < document.styleSheets.length;
  sheetCount++
) {
  const sheet = document.styleSheets[sheetCount].cssRules;
  log(`样式表:${sheetCount}`);

  const myRules = document.styleSheets[sheetCount].cssRules;
  log(`规则:${myRules.length}`);
  for (let i = 0; i < myRules.length; i++) {
    log(`规则:${myRules[i]}`);
    if (myRules[i] instanceof CSSPageRule) {
      //……使用 CSSPageRule 做一些事情
    }
  }
}

结果

结果如下所示。正如你所看到的,有两个样式表,分别对应主文档和示例代码框架,每个样式表都有多个规则,其中只有一个是我们的 CSSPageRule

规范

Specification
CSS Object Model (CSSOM)
# the-csspagerule-interface

浏览器兼容性

BCD tables only load in the browser