Java与XSLT读书笔记(1)

笔记

《Java与XSLT》读书笔记

一,所有的XSLT处理器必须包括四个内置的模版规则,它们的优先级要低于任何其他规则,所以只要编写一个新的模版规则来匹配相同的式样,就可以覆盖它们。理解内置规则的最好方法就是架设它们总是位于后台,如果没有找到其他匹配一个节点的规则,就应用这些内置规则。

<xsl:template match="*|/">

<xsl:apply-templates/>

</xsl:template>

<xsl:template match="*|/" mode="m">

<xsl:apply-templates mode="m"/>

</xsl:template>

<xsl:template match="text()|@*">

<xsl:value-of select="."/>

</xsl:template>

<xsl:template match="processing-instruction()|comment()">

二,XPath

<message>

<header>

<subject>Hello,World</subject>

<date mm="03" dd="01" yy="2002">

<sender>pres@whitehouse.gov</sender>

<recipient>burke_e@ociWeb.com</recipient>

<recipient>burke_e@yahoo.com</recipient>

<recipient>aidan@burke.com</recipient>

</header>

<body>

</body>

</message>

如果<header>为上下文节点,那么child::sbject将选择<subject>节点,而child::recipient将选择所有的<recipient>节点集,child::*将选择<header>的所有子节点。星号(*)字符是一个通配符,表示主要节点类型的所有节点。每个轴都有一个主要节点类型,它始终为元素,除非该轴为属性或命名空间。如果<date>为上下文节点,那么attribute::yy将选择yy属性,而attribute::*将选择<date>元素的所有属性。

简单增加一个谓词过滤结果节点集,通常会减少结果集的大小。增加额外的谓词可进行额外的过滤。例如child::recipient[position()=1]最初将从前一个实例中选择所有的<recipient>元素,然后向下过滤(减少)这个列表直到第一个:burke_e@ociWeb.com位置从1开始,而不是0。谓词可以包含任何XPath表达式,并且变得相当复杂。

如:

<xsl:apply-templates select="presidents/president[position()=3]/name"/>

<xsl:apply-templates select="presidents/president[count(vicePersident)=0]/name"/>

<xsl:apply-templates select="presidents/president[term/@from < 1800]/name"/>

<xsl:apply-templates select="descendant::president[count(vicePresident)>1]/name"/>

<xsl:apply-templates select="presidents/president/name[child::first=’John’]"/>

<xsl: apply-templates

select="presidents/president[(term/@from > 1800) and (term/@from < 1850)]/name">

三,排序

排序可以应用于数据驱动,也可以应用于模板驱动方法。在任一种情况中<xsl:sort>均作为子元素添加到其他部分。通过增加几个连续的<xsl:sort>元素,就可以完成多字段排序。每种排序可以按照升序和降序进行,用于排序的数据类型可以是"数字"或"文本"。排序默认为升序。

<xsl:sort select="first"/>

<xsl:sort select="last" order="descending"/>

<xsl:sort select="term/@from" order="descending" data-type="number"/>

<xsl:sort select="name/first" data-type="text" case-order="upper-first"/>

四,属性值模板(AVT)

只要我们需要将一个属性值视为一个XPath表达式而不是静态文本,可能就需要使用一个AVT。但是对于标准XSLT元素,例如<xsl:template match="pattern"/>,就不必使用AVT语法。对于非XSLT元素,例如任意HTML标签,就需要AVT语法。

五,<xsl:attribute-set>

<xsl:element name="body" use-attribute-sets="body-style"></xsl:element>

六,<xsl:if>

<xsl:if test="boolean-expression">

<!--@@@-->

</xsl:if>

<xsl:if test="middle">检查是否存在一个节点集而不是布尔值

<xsl:if test="@someAttribute"

<xsl:choose>

<xsl:when test="party=’Democratic’">

<xsl text>blue</xsl:text>

</xsl:when>

<xsl:otherwise>

<xsl:text>red</xsl:text>

</xsl:otherwise>

<xsl:choose>

八,参数和变量

<xsl:variable name="lastPresident" select="president[position() = last()]/name"/>

<xsl:value-of select="$lastPresident"/>

九,命名模板

<xsl:template name="formatSSN">

<xsl:param name="ssn"/>

</xsl:template>

<xsl:call-template name="formatSSN">

<xsl:with-param name="ssn" select="@ssn"/>

</xsl:call-template>

十,递增变量

<!--- familyTree.xml ->

<?xml version="1.0" encoding="UTF-8"?>

<?xml-stylesheet type="text/xsl" href="familyTree.xslt"?>

<person name="Otto">

<person name="Sandra">

<person name="Jeremy">

<person name="Eliana"/>

</person>

<person name="Eric">

<person name="Aidan"/>

</person>

<person name="Philip">

<person name="Alex"/>

<person name="Andy"/>

</person>

</person>

</person>

<!--- familyTree.xslt ->

<?xml version="1.0" encoding="UTF-8"?>

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:output method="html"/>

<!-- processing begins here -->

<xsl:template match="/">

<html>

<body>

<!-- select the top level person -->

<xsl:apply-templates select="person">

<xsl:with-param name="level" select="'0'"/>

</xsl:apply-templates>

</body>

</html>

</xsl:template>

<!-- Output information for a person and recursively select

all children. -->

<xsl:template match="person">

<xsl:param name="level"/>

<!-- indent according to the level -->

<div style="text-indent:{$level}em">

<xsl:value-of select="@name"/>

</div>

<!-- recursively select children, incrementing the level -->

<xsl:apply-templates select="person">

<xsl:with-param name="level" select="$level + 1"/>

</xsl:apply-templates>

</xsl:template>

</xsl:stylesheet>

十一,模板模式

<xsl:template match="name" mode="verbose">

</xsl:template>

十二,<xsl:include>与<xsl:import>

<xsl:include>只能作为顶层元素,即它与<xsl:template>是兄弟关系

<xsl:include href="url-reference"/>

当包含两个冲突模板规则时,就会出现问题

<xsl:import>必须出现在<xsl:stylesheet>的任何其他顶层元素之前

十三,格式化文本和数值

string format-number(number, string, string?)

美元$#.##0.00 #和0是数字占位符并严格符合java.text.DecimalFromat指定的行为

0%输出一个百分数

时间: 2024-08-04 00:20:54

Java与XSLT读书笔记(1)的相关文章

Android应用开发提高系列(2)——《Practical Java 中文版》读书笔记(下)

声明 欢迎转载,但请保留文章原始出处:)  博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs.com   系列 Android应用开发提高系列(1)--<Practical Java 中文版>读书笔记(上)    正文  注意:条目和用语可能与书籍有所出入,但尽量保持原样加一些自己的理解. 一.性能 1. 先把焦点放在设计.数据结构和算法身上 备注:良好的设计.明智的选择数据结构和算法可能比高效代码更重要.   2.  不要依赖编译

Java Servlet Programming 读书笔记 - servlet生命周期

servlet|笔记 servlet的生命周期一般为: 1.建立初始化servlet 2.处理从客户端的零个或多个请求 3.销毁servlet,gc回收占用内存 每个server可能在如何支持servlet上有不同的方法,但是上述servlet生命周期却是每个servlet 引擎必须遵守的规则. 实例持久化Instance Persistence: 一个servlet 实例一旦加载,就开始处理对这个servlet的所有请求,换句话说就是一个servlet只生成一个实例.这样的做法对于性能的提高很

《深入理解Java虚拟机》读书笔记

背景 并发处理的广泛应用是使得Amdahl定律代替摩尔定律成为计算机性能发展的源动力的根本原因,也是人类压榨计算机运算能力最有力的武器 Amdahl 定律通过系统中的并行化与串行化的比重来描述多处理器系统能获得的运算加速能力. 摩尔定律则用于描述处理器晶体管数量与运行效率之间的发展关系. 这两个定律的更替代表了近年来硬件发展从追求处理器频率到追求多核心并行处理的发展过程. 高效并发 物理机上的并发解决方案 在当前这个多核处理器时代,"让计算机并发执行若干个运算任务"和"更充分

Android应用开发提高系列(3)——《Effective Java 中文版》读书笔记

声明 欢迎转载,但请保留文章原始出处:)  博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs.com   书籍 <Effective Java 中文版> 03版 潘爱民译 本书介绍了57条极具实用价值的经验规则.这些经验规则涵盖了大多数开发人员每天所面临的问题的解决方案,通过对Java平台设计专家所使用的技术的全面描述,揭示了应坐什么和不应做什么,才能产生清晰.健壮和高效的代码.   正文  注意:条目和用语可能与书籍有所出入,但尽

《淘宝技术这十年》读书笔记 (二).Java时代的脱胎换骨和坚若磐石

        马云说过"一个好的东西往往是是说不清楚的",姑且不论这句话的对与错.但我真的很佩服<淘宝技术这十年>这本书的作者子柳,能够通过淘宝的一些故事,按照时间顺序和IT发展的各种技术描述清楚,而且过程中读起来非常有意思.         该读书笔记中参杂了很多原文的知识,因为我实在无法割舍,都挺有意思的:同时记录一些有用的知识,通过这本书能介绍些学过的知识或面试中可能出现的题目及作者所思,文章还是非常有趣的,希望对大家有所帮助! 一. Java时代 脱胎换骨    

整理java读书笔记十五之java中的内部类_java

内部类是指在一个外部类的内部再定义一个类.类名不需要和文件夹相同. *内部类可以是静态static的,也可用public,default,protected和private修饰.(而外部顶级类即类名和文件名相同的只能使用public和default). 前言  Java从JDK1.1的时候,就开始引入内部类的概念了,那么小编也通过这篇博客来分享一下Java中有关内部类的一些特性.  什么是内部类?  在很多情况下,类被定义成一个独立的程序单元,但是有时候也会把一个类放在另一个类的内部定义,这个定

深入了解JVM-----Inside JVM读书笔记

笔记   本文首先介绍一下Java虚拟机的生存周期,然后大致介绍JVM的体系结构,最后对体系结构中的各个部分进行详细介绍. (  首先这里澄清两个概念:JVM实例和JVM执行引擎实例,JVM实例对应了一个独立运行的java程序,而JVM执行引擎实例则对应了属于用户运行程序的线程:也就是JVM实例是进程级别,而执行引擎是线程级别的.) 一. JVM的生命周期 JVM实例的诞生:当启动一个Java程序时,一个JVM实例就产生了,任何一个拥有public static void main(String

Programming Ruby读书笔记(一)

1. 成员变量的读写属性: attr_reader 和 attr_writer class Test def initialize(name) @name = name end attr_reader :name attr_writer :name end test = Test.new("AAA") puts test.name test.name = "BBB" puts test.name 如果不使用这2个关键字,则按照Java的风格这样写 class Tes

《淘宝技术这十年》读书笔记 (三). 创造技术TFS和Tair

        前面两篇文章介绍了淘宝的发展历程和Java时代的变迁:             <淘宝技术这十年>读书笔记 (一).淘宝网技术简介及来源             <淘宝技术这十年>读书笔记 (二).Java时代的脱胎换骨和坚若磐石         马云说过"创新不是为了与对手竞争,而是跟明天竞争",所以这篇文章讲述淘宝的创新技术TFS和Tair及创新的产品.         该篇文章不仅仅对在读大学生非常有所帮助,因为你能从文章中看到很多你需要学