xsl教程学习笔记

一 . Hello world 尝试:

=============Hello.xml:=================

<?xml version="1.0" encoding="UTF-8"?>
    <?xml-stylesheet type="text/xsl" href="test.xsl"?>
<FistNode>
,World
</FistNode>

===============test.xsl:==================

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:fo="http://www.w3.org/1999/XSL/Format">
    <xsl:template match="/">
        <html>
           <head>
               <title>First node</title>
           </head>
           <body>
               <p>
                  <xsl:value-of select="/FistNode"/>
               </p>
           </body>
        </html>
    </xsl:template>
</xsl:stylesheet>

运行结果:

Hello,World

二 . XSLT元素列表

元素名 含义
xsl:apply-imports 调用重新模板规则
xsl:apply-template 指示XSLT处理器根据每个选定节点的类型和上下文 找到合适的模板
xsl:attribute 创建一个属性节点并将其附加到输出元素上
xsl:attribute-set 定义命名的属性集
xsl:call-template 按名称调用模板
xsl:choose 提供多个与<xsl:otherwise> 元素 和 <xsl:when> 元素有关的条件测试
xsl:comment 在输出中生成注释
xsl:copy 将当前节点从源复制到输出
xsl:copy-of 将子树和结果树片段插入结果树
xsl:decimal-fomat 声明一个小数格式,用于控制formate-number 函数所使用的格式模式解释
xsl:element 在输出中创建指定名称的元素
xsl:fallback 调用可以 为遇到的新的元素的行为 提供合适的替代行为的 模板
xsl:for-each 重复应用模板,对接点集中的每个节点应用模板
xsl:if 允许简单条件模板片段
xsl:import 导入另外一个xslt文件
xsl:include 包含另一个xsl文件
xsl:key 声明一个命名的键,用于XPath表达式中的Key()函数
xsl:message 将文本消息发送到消息缓冲区或者对话框
xsl:namespace-alias 使用其他前缀替换 与给定命名空间关联的前缀
xsl:number 将和格式化的数字插入结果树
xsl:otherwise 提供多个与<xsl:choose>元素和<xsl:when>元素有关的条件测试
xsl:ouput 指定在序列化结果树时使用的选项
xsl:param 声明一个命名参数,在<xsl:stylesheet>元素或者<xsl:template>元素中使用.允许制定默认值
xsl:preserve-space 在文档中保留空白
xsl:sort 指定<xsl:for-each>或者<xsl:apply-template>所选节点列表的排序条件
xsl:stylesheet 指定xslt文件的文档元素.文档元素包含其他XSLT元素
xsl:template 定义一个可以再次使用的模板,用于为特定类型和上下文的节点生成所需要的输出
xsl:text 在输出中生成文本
xsl:transform 执行与<xsl:stylesheet>相同的功能
xsl:value-of 将选定节点的值作为文本插入
xsl:variable 指定表达式中绑定的值
xsl:when 提供多个与<xsl:choose>元素和<xsl:otherwise>有关的测试条件
xsl:with-param 将参数传递给模板
xsl:strip-space 从文档中删除空白

三 xsl:template 和 xsl:apply-template

模板有2部分构成:匹配模式 和 执行.

匹配模式 指定了采用哪个模板 xsl:template

执行指定了如何输出 xsl:apply-template

1.xsl:template语法

<xsl:template natch=pattern name=qname priority=number mode=qname>
<!—执行内容à
</xsl:template>

name:唯一的名称,便于引用

match:原节点模式 与name 必有其一  

priority :-9-9的数字

mode :允许多次处理某个元素, 每次产生不同的结果. 有match就不可以有mode. 

eg:

==========test.xml=============

<?xml version="1.0" encoding="UTF-8"?>
<company>
    <department>
        <name language="Chinese">Tech Department</name>
        <leader>Zhang San</leader>
        <quantity>20</quantity>
        <target>software develop</target>
    </department>
    <department>
        <name language="Chinese">Sale Department</name>
        <leader>Li Si</leader>
        <quantity>20</quantity>
        <target>Sale work</target>
    </department>
</company>

1.匹配所有的部门

<xsl:template match=”department”></xsl:template>

2.匹配所有的领导和所有的人数元素

<xsl:template match=”leader|quantity”></xsl:template>

3.匹配所有父节点为 部门的 领导元素

<xsl:template match=”department//leader”></xsl:template>

3.匹配根节点

<xsl:template match=”/”></xsl:template>

2.xsl:apply-templates

语法:

<xsl:apply-templates select=node set-expression mode=qname></xsl:apply-templates>

用来 表示 哪个节点被模板具体处理.可以理解为 调用子函数 select用来选择确切的节点名字. xsl:apply-templates 总是在 xsl: template中

1.模板匹配整个文档(根节点), 具体执行时 处理根节点下的所有部门元素.

<xsl:template match=”/”>
    <xsl:apply-template select=”department”/>
</xsl:template>

2.模板匹配 部门 节点. 具体执行时 部门下所有的子元素都将被处理

<xsl:template match=”para”>
    <p><xsl:apply-template /></p>
</xsl:template>

四 xsl:value-of

用来将 文档中的元素 文本 写入到 输出文档中.

1.    提取出部门中每个领导人的名字

<xsl:template match=”department”>
    < xsl:value-of select=”leader”/>
</xsl:template>

心得: <xsl:template match=”department”>表示一个范围,然后value-of和apply-template明确指出到底是哪些元素

时间: 2024-10-03 05:14:46

xsl教程学习笔记的相关文章

JS教程:学习笔记之JS类

背景:接触JavaScript快两年了.从最开始对她充满着好奇,到现在的学习了许多关于她的框架.朋友问我:都有这么多框架,你为何还要去学最底层的面向对象呢?其实这个问题:另一个朋友已经替我回答了.无论以后框架在怎么变,只要了解底层的原理,学起来都是很容易上手的.好了,我们开始学习了. 1.    创建对象: var obj = new Object();//第一种方式. var obj = {};//第二种方法.顺带一句可以通过var arr = [] 来创建数组 2.    给对象的属性赋值

简明Python教程学习笔记_6_面向对象编程

简介 类和对象是面向对象编程的两个主要方面.类创建一个新类型,而对象这个类的 实例 .这类似于你有一个int类型的变量,这存储整数的变量是int类的实例(对象). 类(Class)::用来描述具有相同的属性和方法的对象的集合.它定义了该集合中每个对象所共有的属性和方法.对象是类的实例. 对象:          通过类定义的数据结构实例.对象包括两个数据成员(类变量和实例变量)和方法. 实例化:      创建一个类的实例,类的具体对象.方法:          类中定义的函数. (方法和函数在

简明Python教程学习笔记_4_数据结构

在Python中有三种内建的数据结构--列表.元组和字典. 列表 list是处理一组有序项目的数据结构,即你可以在一个列表中存储一个 序列 的项目.假想你有一个购物列表,上面记载着你要买的东西,你就容易理解列表了.只不过在你的购物表上,可能每样东西都独自占有一行,而在Python中,你在每个项目之间用逗号分割. 列表中的项目应该包括在方括号中,这样Python就知道你是在指明一个列表.一旦你创建了一个列表,你可以添加.删除或是搜索列表中的项目.由于你可以增加或删除项目,我们说列表是可变的 数据类

简明Python教程学习笔记_8_sys和os

sys模块包含系统对应的功能.我们已经学习了sys.argv列表,它包含命令行参数. #!/usr/bin/python # Filename: cat.py import sys def readfile(filename):  '''Print a file to the standard output.'''  f = file(filename)  while True:     line = f.readline()    if len(line) == 0:      break 

简明Python教程学习笔记_7_输入输出

输入/输出 在很多时候,你会想要让你的程序与用户(可能是你自己)交互.你会从用户那里得到输入,然后打印一些结果.我们可以分别使用raw_input和print语句来完成这些功能.对于输出,你也可以使用多种多样的str(字符串)类.例如,你能够使用rjust方法来得到一个按一定宽度右对齐的字符串.利用help(str)获得更多详情. 另一个常用的输入/输出类型是处理文件.创建.读和写文件的能力是许多程序所必需的 文件 你可以通过创建一个file类的对象来打开一个文件,分别使用file类的read.

简明Python教程学习笔记_3_模块

模块 如果你想要在其他程序中重用很多函数,那么你该如何编写程序呢?你可能已经猜到了,答案是使用模块.模块基本上就是一个包含了所有你定义的函数和变量的文件.为了在其他程序中重用模块,模块的文件名必须以.py为扩展名. python有三种导入模块的方法 其一, import modname : 模块是指一个可以交互使用,或者从另一Python 程序访问的代码段.只要导入了一个模块,就可以引用它的任何公共的函数.类或属性.模块可以通过这种方法来使用其它模块的功能. 用import语句导入模块,就在当前

Python基础教程学习笔记 第一章 基础知识_Android

1.python的每一个语句的后面可以添加分号也可以不添加分号:在一行有多条语句的时候,必须使用分号加以区分 2.查看Python版本号,在Dos窗口中输入"python -V"查看版本号,注意V是大写字母,这条命令是Windows命令,而不是python shell的命令 3.让解释器只执行普通的除法运算:from __feture__ import division 4.执行整除运算的运算符:// 5.取幂运算符:2**4 相当于2的4次方,-2**4相当于2的4次方之后取负,因为

Python基础教程学习笔记 第二章 列表和元组_Android

1.序列中元素的索引: 第一个元素索引是0,第二个是1,依次递增 最后一个元素索引是-1,倒数第二个是-2,依次递减 2.序列(Sequence)的种类: 列表(list).元组(tuple).字符串(string).Unicode 字符串.buffer对象.xrange对象 3.列表和元组的区别:列表可以进行修改,但是元组不行 4.tuple常作为字典的键 5.序列都可以进行以下操作: 索引(indexing).分片(sliceing).加(adding).乘(multiplying).以及检

Node.js入门教程学习笔记分享(1/8)

什么是Node.js Node.js 是服务器端的 JavaScript 运行环境,它允许在后端(脱离浏览器环境)运行JavaScript代码.Node.js具有无阻塞(non-blocking)和事件驱动(event-driven)等的特色,它实现了类似 Apache 和 nginx 的web服务,让你可以通过它来搭建基于 JavaScript 的 Web App. 要实现在后台运行JavaScript代码,代码需要先被解释然后正确的执行,Node.js的原理正是如此,它使用了Google的V