zoukankan      html  css  js  c++  java
  • 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对象规定继承属性
  • 相关阅读:
    又来项目了,星座运势widget
    ubuntu下编译android源代码
    Android UI,界面辅助设置工具,可随意拖动控件,比google官方提供的方便
    Android 1.5原生软件开发SDK公布
    REST转自WIKI
    Android SDK 1.5 包装索引
    android google market FreshFace上线了,大家都试用试用,反正免费的
    JSON
    ubuntu命令
    网站支付宝接口错误代码:TRADE_DATA_MATCH_ERROR怎么处理? uz
  • 原文地址:https://www.cnblogs.com/rongfengliang/p/3903191.html
Copyright © 2011-2022 走看看