首页 > 代码库 > 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对象规定继承属性 |
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。