首页 > 代码库 > xsl -fo 了解

xsl -fo 了解

XSL-FO是用于格式化XML数据的语言,全称为Extensible Stylesheet Language Formatting Objects(格式化对象的可扩展样式表语言),是W3C参考标准,现在通常叫做XSL。

什么是 XSL-FO

XSL-FO 是用于格式化 XML 数据的语言
XSL-FO 指可扩展样式表语言格式化对象(Extensible Stylesheet Language Formatting Objects)
XSL-FO 是一个 W3C 推荐标准
XSL-FO 目前通常被称为 XSL

通常被称为 XSL

为什么会存在这样的混淆呢?XSL-FO 和 XSL 是一回事吗?
可以这么说,不过我们需要向您作一个解释:
样式化(Styling)是关于转换信息格式化信息两方面的信息。在万维网联盟编写他们的首个 XSL 工作草案的时候,这个草案包括了有关转换和格式化 XML 文档的语言语法。
后来,XSL 工作组把这个原始的草案分为独立的标准:
XSLT,用于转换 XML 文档的语言
XSL 和 XSL-FO,用于格式化 XML 文档的语言
XPath,是通过元素和属性在 XML 文档中进行导航的语言
XSL-FO 使用矩形框(区域)来显示输出。
 

XSL-FO 区域编辑

XSL 格式化模型定义了一系列的矩形区域(框)来显示输出。
所有的输出(文本、图片,等等)都会被格式化到这些框中,然后会被显示或打印到某个目标媒介。
让我们研究一下下面这些区域:[1] 
  • 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 文档

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" 等等。
 

XSLFO 对象

对象
描述
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对象规定继承属性