xslt语法之---基础语法
1. XSLT常用元素:
1.1 <xsl:template>:创建模板
Match属性的作用是使模板和XML元素相关联
<xsl:template match="\">......</xsl:template>
1.2 <xsl:value-of>:选取XML元素,并添加到已被转换的输出流中
<xsl:value-of select = "xpath"/>
1.3 <xsl:for-each>:循环
1.4 <xsl:sort>:对结果进行排序
<xsl:for-each select ="catalog/cd["article='Bob']">
<xsl:sort select="article"/>
.....
</xsl:for-each>
在我实际练习时,发现如果select属性中若要带参数,需要按照如下语法:
<xsl:sort select="*[name()=$param1Name]" order="{$para2Name}"/>
1.5 <xsl:if>:相当于if-then
<xsl:if test="price>10">
......
</xsl:if>
1.6 <xsl:choose>:相当于if-then-else
<xsl:choose>
<xsl:when test="expression">
......
</xsl:when>
<xsl:otherwise>
......
</xsl:otherwise>
</xsl:choose>
2. XSLT常用函数
2.1 current():返回当前节点
<xsl:value-of select="current()"/>
等效于
<xsl:value-of select="."/>
2.2 document():访问一个外部的XML文档的节点
<xsl:value-of select="document('other.xml')/root/xpath"/>
实际应用中,貌似document后面的接的Xpath中不能带参数变量,例如这样会出现解析错误:"document('other.xml')/root/$paramName/ChildNode"
2.3 element-available():测试指定的元素是否能被XSLT处理器支持
<xsl:when test="element-available('xsl:comment')">
判断是否支持注释
</xsl:when>
2.4 format-number():数字转换为字符串
<value-of select="format-number(500,'#.00')"/>
2.5 function-available():测试是否支持该函数
<xsl:if test="function-availabel('current')">
......
</xsl:if>
2.6 generate-id():返回自增独立唯一标识,类似于SQL中的identity(1,1)
2.7 key():使用由<xsl:key>指定的索引[index],从当前文档中返回一个节点组;
<xsl:for-each select="key('string','object')">
......
</xsl:for-each>
2.8 system-property():返回通过name属性指定的系统属性值
<xsl:value-of select="system-property('xsl:version')"/>
2.9 unprased-entity-uri():返回未解析实体的URI.
3. JS传参数给XSLT:
JS中:
var xml = new ActiveXObject("MSXML2.DOMDocument");
xml.load("filename.xml");
var xsl = new ActiveXObject("MSXML2.FreeThreadedDOMDocument");
xsl.load("filename.xsl");
var xslTemplate = new ActiveXObject("MSXML2.XSLTemplate");
xslTemplate.stylesheet = xsl;
var xslProcessor = xslTemplate.createProcessor();
xslProcessor.input = xml;
xslProcessor.addParameter("ParamName", paramValue);
xslProcessor.transform();
XSLT中:
<param name="ParamName"></param>
用$ParamName取得参数的值
xslt语法之---基础语法的更多相关文章
- Python语法教程-基础语法01
目录 1. Python应用 2. 在Linux中写python 3. Python基础语法 1. 注释 2. 变量定义及类型 3. 格式化输出 4. 用户输入 5. 运算符 6.数据转换 7. 判断 ...
- python 全栈开发,Day89(sorted面试题,Pycharm配置支持vue语法,Vue基础语法,小清单练习)
一.sorted面试题 面试题: [11, 33, 4, 2, 11, 4, 9, 2] 去重并保持原来的顺序 答案1: list1 = [11, 33, 4, 2, 11, 4, 9, 2] ret ...
- python语法_1基础语法概述
http://www.runoob.com/python3 章节:教程.基础语法.数据类型.解释器.注释.运算符. 大纲 查看python版本 实现第一个python3.x程序,hello world ...
- python基础语法之基础语法规则以及设置
1. 编码格式 在python3以上版本中,py文件默认采用UTF-8格式编码,所有的字符串都是unicode字符串.当然,我们也可以自己为源码文件指定不同的编码,以utf-8为例,相关代码如下所示: ...
- Scala语法01 - 基础语法
- 07_Python语法示例(基础语法,文件操作,异常处理)
1.写程序在终端输出图形 ######## # # # # ######## print("#" * 8) print("#" + " " ...
- 3.Scala语法01 - 基础语法
- JSP/Servlet基础语法
相关学习资料 http://my.oschina.net/chape/blog/170247 http://docs.oracle.com/cd/E13222_01/wls/docs81/webapp ...
- Swift与C#的基础语法比较
背景: 这两天不小心看了一下Swift的基础语法,感觉既然看了,还是写一下笔记,留个痕迹~ 总体而言,感觉Swift是一种前后端多种语言混合的产物~~~ 做为一名.NET阵营人士,少少多多总喜欢通过对 ...
随机推荐
- id类型
id类型 在Objective-C 中,id 类型是一个独特的数据类型.在概念上,类似Java 的Object 类,可以转换为任何数据类型.换句话说,id 类型的变量可以存放任何数据类型的对象.在内部 ...
- Data Guard配置后续检查
Data Guard配置后续检查 1.打开生产端节点192.166.1.190上的数据库实例: SQL>startup; 2.打开容灾端节点192.166.1.60上的数据库实例: SQL> ...
- bzoj 2002: [Hnoi2010]Bounce 弹飞绵羊 動態樹
2002: [Hnoi2010]Bounce 弹飞绵羊 Time Limit: 10 Sec Memory Limit: 259 MBSubmit: 4055 Solved: 2172[Submi ...
- bzoj 1053: [HAOI2007]反素数ant 搜索
1053: [HAOI2007]反素数ant Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1497 Solved: 821[Submit][Sta ...
- Illustrator软件中eps和ai格式的区别
转自Illustrator软件中eps和ai格式的区别 AI是ILL特有的格式,EPS格式是在排版领域经常使用的格式.AI中的位图图像是用链接的方式存储,EPS格式则将位图图像包含于文件中.对于含有相 ...
- 3d max export for unity3d
3d max export for unity3d @by 广州小龙 1.单位问题 建模的时候,设置unity的Units Setup的单位是Meters,导出FBX文件的时候,单位为厘米(Centi ...
- ‘char *' differs in levels of indirection from 'int'
这个问题是有与和系统变量重名导致的,如 char* ans = (char*) malloc(10);系统变量是一个int.
- 《STL源码剖析》chapter2空间配置器allocator
为什么不说allocator是内存配置器而说是空间配置器,因为空间不一定是内存,也可以是磁盘或其他辅助介质.是的,你可以写一个allocator,直接向硬盘取空间.sgi stl提供的配置器,配置的对 ...
- 执行计划之CONCATENATION
CREATE TABLE T_CONCAT (ID NUMBER, NAME VARCHAR2(30), TYPE VARCHAR2(30)); INSERT INTO T_CONCAT SELECT ...
- 利用no_merge优化
SQL> select a.unit3_code 机构编码, 2 a.unit3_name 机构名称, 3 a.dept1_code 部门编码, 4 a.dept1_name 部门名称, 5 a ...