XSLT轻松入门第三章:XSLT的元素语法

简介: XSLT轻松入门第三章:XSLT的元素语法  通过前面两章的介绍,我们已经对XSLT的基本概念和它的转换过程有了一些了解。下面我们一起来学习XSLT的具体语法。

XSLT轻松入门第三章:XSLT的元素语法

  通过前面两章的介绍,我们已经对XSLT的基本概念和它的转换过程有了一些了解。下面我们一起来学习XSLT的具体语法。说到语法总是比较枯燥的,您可以大体上浏览一遍,等您真正需要使用XSLT的时候,再仔细研究它们。 

3.XSLT的元素语法 

3.1 xsl:templatexsl:apply-templates 

3.2 xsl:value-of 

3.3 xsl:for-each 

3.4 xsl:if 

3.5 Xxsl:choose, when, otherwise 

3.6 xsl:sort 

3.1 xsl:templatexsl:apply-templates

模板(template)XSLT中最重要的概念之一。XSLT文件就是由一个一个的模板组成,任何一个XSLT文件至少包含一个模板。模板的概 念就象是搭积木;你如果是程序员,也可以将模板看作一个方法,一个类,或者一个模块。它们可以被拼装组合,也可以单独成块,不同的模板控制不同的输出格 式。

模板(template)由两部分组成:匹配模式(match pattern)和执行。简单的讲模式定义XML源文档中哪一个节点将被模板处理,执行则定义输出的是什么格式。两部分对应的语法为xsl:templatexsl:apply-templates

xsl:template的语法是:

<xsl:template

match = pattern

name = qname

priority = number

mode = qname>

<!-- 执行内容 -->

</xsl:template>

xsl:template的作用是定义一个新模板。属性中name,priority,mode用来区别匹配同一节点的不同模板。它们不是常用的 属性。match属性则控制模板的匹配模式(pattern),匹配模式是用来定位XML源文档中哪一个节点被模板处理。一个模板匹配一个节点。我们用一 个例子来帮助理解:

假设我们要处理一个包含章节和段落文档。我们用para元素定义段落,用chapter元素定义章节。我们来看看match属性可能的值。下面的语句写法说明模板匹配所有的para元素

<xsl:template match="para">

</xsl:template>

下面的语句写法说明模板匹配所有的para元素和所有的chapter元素:

<xsl:template match="(chapter|para)">

</xsl:template>

下面的语句写法说明模板匹配所有的父节点为chapter元素的para元素:

<xsl:template match="chapter//para">

</xsl:template>

下面的语句写法说明模板匹配根节点:

<xsl:template match="/">

</xsl:template>

我们再来看apply-templates语法:

<xsl:apply-templates

select = node set-expression

mode = qname>

</xsl:apply-templates>

xsl:apply-templates用来执行那一个节点被模板具体处理。你可以将它理解为程序中调用子函数。select属性用来定义确切的节点名称。xsl:apply-templates总是包含在xsl:template元素中,象这样:

<xsl:template match="/">

<xsl:apply-templates select="para"/>

</xsl:template>

 

这段代码说明摸板匹配整个文档(根节点),具体执行时处理根节点下所有para元素
 

<xsl:template match="para">

<p><xsl:apply-templates/></p>

</xsl:template>

而这一段代码则表示摸板匹配para节点,所有para下的子元素都将被处理。

3.2 xsl:value-of

XSL:value-of用来将源文档中元素的文本值写到输出文档中。例如:

有一个个人资料的XML文档:

<?xml version="1.0" encoding="iso-8859-1"?>

<PERSON>

<name>ajie</name>

<age>28</age>

</PERSON>

我如果想在输出文档中显示上面这个XML源文档中的name元素的值,可以这样写XSLT代码:

<xsl:template match="PERSON">

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

</xsl:template>

后,你会看到"ajie"被单独显示出来。其中match="PERSON"定义摸板匹配PERSON节点,xsl:value-of 
语 法说明需要输出一个节点的值,而select="name"则定义需要被输出的元素为name。看这个过程是不是和数据库里查询一个人的名字很象?当然, xsl:value-of查询还有更多,更复杂的语法,因为是涉及寻找和定位的功能,我们会放在后面的XPath语法中在仔细讲解。

同样功能的还有xsl:copy-of,用法一样,就不重复解释了。

3.3 xsl:for-each

xsl:for-each语法允许你循环处理被选择的节点。例如:有一个含多个个人资料的XML文档:

<?xml version="1.0" encoding="iso-8859-1"?>

<PEOPLE>

<PERSON>

<name>ajie</name>

<age>28</age>

</PERSON>

<PERSON>

<name>tom</name>

<age>24</age>

</PERSON>

<PERSON>

<name>miake</name>

<age>30</age>

</PERSON>

</PEOPLE>

我需要显示所有人的姓名,则可以将XSLT代码写成:

<xsl:template match="PEOPLE">

<xsl:for-each select="child::PERSON">

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

</ xsl:for-each>

</xsl:template>

3.4 xsl:if 

xsl:if类似普通程序语言的if条件语句,允许设定节点满足某个条件时,被模板处理。xsl:if的语法格式为: 

<xsl:if test=布尔表达式>

template body

</xsl:if>

例如:

<xsl:template match="PEOPLE">

<xsl:if test="@name"> 

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

</xsl:if>

</xsl:template>

这段代码的意思是检测PEOPLE节点下所有的元素,如果发现有<name>元素,则将<name>元素的值输出。其中@符号是统配符,表示节点下所有的元素。

3.5 xsl:choose, xsl:when 和 xsl:otherwise
 

xsl:if语法没有else的属性。如果我们要进行多项选择,那么就要使用xsl:choose / xsl:when / xsl:otherwise系列流程控制语法了。具体的使用请看下面的XSL文件例子:
 

<xsl:template match="PEOPLE">

<xsl:choose>

<xsl:when test="@name = 'ajie'">

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

</xsl:when>

<xsl:when test="@name">

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

</xsl:when> 

<xsl:otherwise>

No name available

</xsl:otherwise>

<xsl:choose>

</xsl:template>
 

说明:首先在PEOPLE节点下寻找<name>属性值为ajie的元素,如果找到,将ajie用粗体输出;如果没有发现值为ajie <name>元素,则将所有的<name>元素的值都用斜体输出;如果没有发现任何<name>元素,则显示 "No 
name available"。 

3.6 xsl:sort
 

XSLT中可以对XML源文档的元素进行重新排序,排序的语法就是xsl:sort。举例:下面的代码就是将文档元素按name排序。 

<xsl:template match="PEOPLE">

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

<xsl:sort select="@name"/>

</xsl:apply-templates>

</xsl:template>

以上是XSLT的元素的主要语法,还有很多其他的语法,例如:import, include, element, attribute, number, param等等语法,在这里就不一一解释。我们的目的是让您对XSLT的语法有基本的概念,理解XSLT作为一种转换语言的强大功能。



相关文章
|
机器学习/深度学习 自然语言处理 算法
3大核心技术,免费开源的智能合同审查分析软件的技术介绍
智能法律文档分析系统基于BERT、GPT等模型,实现高精度的实体识别和关系抽取,准确率分别达95%和90%以上。系统支持跨文档关联分析和实时处理,响应时间小于1秒,显著提升文档处理效率。核心算法包括深度学习模型、关系抽取技术和多层次数据处理能力,适用于复杂的法律文书分析。
980 0
3大核心技术,免费开源的智能合同审查分析软件的技术介绍
|
存储 算法 C语言
C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项
本文深入探讨了C语言中常见的字符串处理技巧,包括字符串的定义、初始化、输入输出、长度计算、比较、查找与替换、拼接、截取、转换、遍历及注意事项,并通过案例分析展示了实际应用,旨在帮助读者提高编程效率和代码质量。
900 4
|
开发框架 前端开发 JavaScript
循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(10) -- 在DataGrid上直接编辑保存数据
循序渐进介绍基于CommunityToolkit.Mvvm 和HandyControl的WPF应用端开发(10) -- 在DataGrid上直接编辑保存数据
|
存储 数据可视化 大数据
大数据平台架构设计与实施
【7月更文挑战第3天】本文探讨了大数据平台的关键技术,包括数据采集(如Kafka、Flume)、存储(HDFS、HBase、Cassandra)、处理(Hadoop、Spark)、分析挖掘及可视化工具。架构设计涉及数据收集、存储、处理、分析和应用层,强调各层次的协同与扩展性。实施步骤涵盖需求分析、技术选型、架构设计、系统部署、数据迁移、应用开发测试及上线运维,旨在为企业决策提供强有力的数据支持。
1261 3
|
传感器
西门子 PCS 7 工程师站及 PDM 如何安装?
本篇我们来介绍一下西门子 PCS 7 工程师站及 PDM 如何安装。我们先来看一张图,下图显示了西门子PCS7系统中各类PC站的系统结构。在安装过程中,应该根据每个PC站的不同功能定义来选择正确的安装选项。
西门子 PCS 7 工程师站及 PDM 如何安装?
|
存储 监控 安全
网络存储解决方案:选择与配置
网络存储解决方案:选择与配置
509 0
|
XML JSON 前端开发
Spring之RequestBody的使用姿势小结
SpringMVC中处理请求参数有好几种不同的方式,如我们常见的下面几种 根据 HttpServletRequest 对象获取 根据 @PathVariable 注解获取url参数 根据 @RequestParam 注解获取请求参数 根据Bean的方式获取请求参数 根据 @ModelAttribute 注解获取请求参数
1116 0
Spring之RequestBody的使用姿势小结
|
虚拟化 Windows
vmware安装Windows7之后VMware tools显示灰色无法安装的解决办法(终结版解决方案)
vmware安装Windows7之后VMware tools显示灰色无法安装的解决办法(终结版解决方案)
3167 0
vmware安装Windows7之后VMware tools显示灰色无法安装的解决办法(终结版解决方案)