XSL-FO
目录
XSL-FO 是用于格式化 XML 数据的语言
XSL-FO 指可扩展样式表语言格式化对象(Extensible Stylesheet Language Formatting Objects)
XSL-FO 是一个 W3C 推荐标准
XSL-FO 目前通常被称为 XSL
可以这么说,不过我们需要向您作一个解释:样式化(Styling)是关于转换信息和格式化信息两方面的信息。在万维网联盟编写他们的首个 XSL 工作草案的时候,这个草案包括了有关转换和格式化 XML 文档的语言语法。后来,XSL 工作组把这个原始的草案分为独立的标准:XSLT,用于转换 XML 文档的语言;XSL 和 XSL-FO,用于格式化 XML 文档的语言;
XPath,是通过元素和属性在 XML 文档中进行导航的语言;XSL-FO 使用矩形框(区域)来显示输出。
XSL 格式化模型定义了一系列的矩形区域(框)来显示输出。
所有的输出(文本、图片,等等)都会被格式化到这些框中,然后会被显示或打印到某个目标媒介。
让我们研究一下下面这些区域:
Pages(页面)
Regions(区)
Block areas(块区域)
Line areas(行区域)
Inline areas(行内区域)
XSL-FO Pages(页面)
XSL-FO 输出会被格式化到页面中。打印输出通常会分为许多分割的页面。浏览器输出经常会成为一个长的页面。
XSL-FO Pages(页面)包含区(Region)。
XSL-FO Regions(区)
每个 XSL-FO 页面均包含一系列的 Regions(区):
region-body(页面的主体)
region-before(页面的页眉)
region-after(页面的页脚)
region-start(左侧栏)
region-end(右侧栏)
XSL-FO Regions(区)包含块区域(Block Area)。
XSL-FO Block Areas(块区域)
XSL-FO Block Areas(块区域)定义了小的块元素(通常由一个新行开始),比如段落、表格以及列表。
XSL-FO Block Areas(块区域)包含其他的块区域,不过大多数时候它们包含的是行区域(Line Area)。
XSL-FO Line Areas(行区域)
XSL-FO Line Areas(行区域)定义了块区域内部的文本行。
XSL-FO Line Areas(行区域)包含行内区域(Inline Area)。
XSL-FO Inline Areas(行内区域)
XSL-FO Inline Areas(行内区域)定义了行内部的文本(着重号、单字符、图像,等等)。
XSL-FO 文档是带有输出信息的 XML 文件。
XSL-FO 文档是带有输出信息的 XML 文件。它们包含着有关输出布局以及输出内容的信息。
XSL-FO 文档存储在以 .fo 或 .fob 为后缀的文件中。以 .xml 为后缀存储的 XSL-FO 文档也很常见,这样做的话可以使 XSL-FO 文档更易被 XML 编辑器存取。
XSL-FO 文档的结构
XSL-FO 的文档结构类似这样:
<?xml version="1.0" encoding="ISO-8859-1"?>
<fo:root xmlns:fo="/1999/XSL/Format">
<fo:layout-master-set>
<fo:simple-page-master master-name="A4">
<!-- Page template goes here -->
</fo:simple-page-master>
</fo:layout-master-set>
<fo:page-sequence master-reference="A4">
<!-- Page content goes here -->
</fo:page-sequence>
</fo:root>结构解释
XSL-FO 文档属于 XML 文档,因为也需要以 XML 声明来起始:
<?xml version="1.0" encoding="ISO-8859-1"?><fo:root> 元素是 XSL-FO 文档的根元素。这个根元素也要声明 XSL-FO 的命名空间:
<fo:root xmlns:fo=org/1999/XSL/Format">
<!-- 此处是 XSL-FO 文档的内容 -->
</fo:root><fo:layout-master-set> 元素含有一个或多个页面模板:
<fo:layout-master-set>
<!-- 此处是所有的页面模板 -->
</fo:layout-master-set><fo:simple-page-master> 元素包含一个单一的页面模板。每个模板须有一个唯一的名称(master-name):
<fo:simple-page-master master-name="A4">
<!-- 此处是某一个页面模板 -->
</fo:simple-page-master>一个或多个 <fo:page-sequence> 元素可描述页面的内容。master-reference 属性使用相同的名称来引用 simple-page-master 模板:
<fo:page-sequence master-reference="A4">
<!-- 此处是页面内容 -->
</fo:page-sequence>注释:master-reference 的值 "A4" 实际上并没有描述某个预定义的页面格式。它仅仅是一个名称。您可以使用任何名称,比如 "MyPage"、"MyTemplate" 等等。
对象 |
描述 |
basic-link |
定义一个链接的起始资源 |
bidi-override |
Overrides the default Unicode BIDI direction |
block |
定义一个输出块(比如段落和标题) |
block-container |
定义一个块级的引用区域(reference-area) |
character |
定义一个字符,该字符会被映射为供呈现的字形 |
color-profile |
定义样式表的一个颜色配置文件 |
conditional-page-master-reference |
规定一个当所定义的条件成立时使用的page-master |
declarations |
组合针对某个样式表的全局声明 |
external-graphic |
用于图像数据位于XML结果树之外的某个图形 |
float |
典型的用法是,在页面起始位置的某个单独的区域放置一幅图片,或者把一幅图片放置到一侧,而内容则流动至图片的旁边。 |
flow |
包含所有被输出到页面的元素 |
footnote |
定义在页面的region-body内部的一个脚注 |
footnote-body |
定义脚注的内容 |
initial-property-set |
格式化<fo:block>的第一行 |
inline |
通过背景或者将其包围在一个边框中,来格式化文本的某个部分 |
inline-container |
定义一个行内的引用区域(inline reference-area) |
instream-foreign-object |
用于行内图形(inline graphics)或用于普通对象,其中对象的数据作为<fo:instream-foreign-object>的后代存在。 |
layout-master-set |
存有所有用在文档中的master |
leader |
用来生成"."由内容表格中的页码来分隔标题,或者创建表单中的输入域,或者创建水平线 |
list-block |
定义列表 |
list-item |
包含列表中的每个项目 |
list-item-body |
包含列表项的内容或主体 |
list-item-label |
包含列表项的标号(有代表性的是数据、字符等等) |
marker |
与fo:retrieve-marker使用来创建连续的页面或页脚 |
multi-case |
包含 XSL-FO对象的每个供选择的子树(在<fo:multi-switch>内部)。父元素<fo:multi-switch>会选择显示那个选项并隐藏其余的选项。 |
multi-properties |
用来在两个或更多的属性集(property-sets)间转换 |
multi-property-set |
规定一个可供选择的属性集,这个属性集会被根据用户代理的状态来进行应用。 |
multi-switch |
存有一个或多个<fo:multi-case>对象,并控制它们之间的切换(通过<fo:multi-toggle>激活) |
multi-toggle |
用来切换到另一个<fo:multi-case> |
page-number |
表示当前的页面 |
page-number-citation |
为页面引用页码,此页面包含首个由被引用对象返回的标准区域。 |
page-sequence |
一个针对页面输出元素的容器。在其中一个<fo:page-sequence>对象针对每个页面布局。 |
page-sequence-master |
规定使用哪个simple-page-master,以及使用次序。 |
region-after |
定义页脚 |
region-before |
定义页眉 |
region-body |
定义页面主体 |
region-end |
定义页面的右侧栏 |
region-start |
定义页面的左侧栏 |
repeatable-page-master-alternatives |
定义一套simple-page-master的副本 |
repeatable-page-master-reference |
规定一个简单的simple-page-master的副本 |
retrieve-marker |
与<fo:marker>一同使用来创建连续页眉或者页脚 |
root |
XSL-FO文档的根(顶)节点 |
simple-page-master |
定义页面的尺寸和形状 |
single-page-master-reference |
规定用在页面序列的某个给定的点的一个 |
static-content |
包含在许多页面上重复的静态内容(比如页眉和页脚) |
table |
格式化一个表格的表格式的材料 |
table-and-caption |
格式化一个表格及其标题 |
table-body |
表格行和表格单元的容器 |
table-caption |
包含一个表格的标题 |
table-cell |
定义表格单元 |
table-column |
格式化表格的列 |
table-footer |
定义表格的页脚 |
table-header |
定义表格的页眉 |
table-row |
定义表格的行 |
title |
为页面序列定义一个标题 |
wrapper |
为一组XSL-FO对象规定继承属性 |
附件列表
故事内容仅供参考,如果您需要解决具体问题
(尤其在法律、医学等领域),建议您咨询相关领域专业人士。
