XSL-FO 文档

XSL-FO 文档是带有输出信息的 XML 文件。


XSL-FO 文档

XSL-FO 文档是带有输出信息的 XML 文件。它们包含着有关输出布局以及输出内容的信息。

XSL-FO 文档存储在以 .fo 或 .fob 为后缀的文件中。以 .xml 为后缀存储的 XSL-FO 文档也很常见,这样做的话可以使 XSL-FO 文档更易被 XML 编辑器存取。


XSL-FO 文档的结构

XSL-FO 的文档结构类似这样:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format">
  3. <fo:layout-master-set>
  4. <fo:simple-page-master master-name="A4">
  5. <!-- Page template goes here -->
  6. </fo:simple-page-master>
  7. </fo:layout-master-set>
  8. <fo:page-sequence master-reference="A4">
  9. <!-- Page content goes here -->
  10. </fo:page-sequence>
  11. </fo:root>
结构解释

XSL-FO 文档属于 XML 文档,因为也需要以 XML 声明来起始:

  1. <?xml version="1.0" encoding="utf-8"?>

<fo:root> 元素是 XSL-FO 文档的根元素。这个根元素也要声明 XSL-FO 的命名空间:

  1. <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format">
  2. <!-- 此处是 XSL-FO 文档的内容 -->
  3. </fo:root>

<fo:layout-master-set> 元素含有一个或多个页面模板:

  1. <fo:layout-master-set>
  2. <!-- 此处是所有的页面模板 -->
  3. </fo:layout-master-set>

<fo:simple-page-master> 元素包含一个单一的页面模板。每个模板须有一个唯一的名称(master-name):

  1. <fo:simple-page-master master-name="A4">
  2. <!-- 此处是某一个页面模板 -->
  3. </fo:simple-page-master>

一个或多个 <fo:page-sequence> 元素可描述页面的内容。master-reference 属性使用相同的名称来引用 simple-page-master 模板:

  1. <fo:page-sequence master-reference="A4">
  2. <!-- 此处是页面内容 -->
  3. </fo:page-sequence>

注释:master-reference 的值 "A4" 实际上并没有描述某个预定义的页面格式。它仅仅是一个名称。您可以使用任何名称,比如 "MyPage"、"MyTemplate" 等等。