XML通过XSL格式化的那点事(XML到自定义节点折叠显示)
引言
有时我们想看下系统生成的XML文件(如XML格式的Project文件),如果文件结构简单,我们浏览器看起来还比较方便,但是随着XML schema复杂后就变得让人头疼啦,单独写一个程序去做展现又有点小题大做。这时XSL就用体现它的价值啦,当然XSL不只是为了显示,更多的目的是从一个格式生成另个一格式的XML或者其他格式的文件。本文只说说格式化。
过程中遇到的问题解决方法
效果图

XSL常用元素
xsl:template定义匹配节点的转换模板,属性match=”xpath expression”用来定义模板匹配的元素
如下定义匹配根节点的模板
<xsl:template match=”/”> </xsl:template>
xsl:for-each循环显示select=”xpath expression”选择节点的转换 (类似编程语言中的foreach语句),
如下示例,选择了pets下面的子元素,并循环显示子元素的几点名字:
<xsl:for-each select=”/pets/*”> <xsl:value-of select=”name()”/> </xsl:for-each>
xsl:if 元素条件显示节点(类似编程语言中的if语句)注意小于号大于号要分别用<和>替代
<xsl:if test=”@weight < 10”> <i>its weight is less than 10 km</i> </xsl:if>
xsl:choose 多分支条件显示 (类似编程语言中的switch语句)
<xsl:choose > <xsl:when test=”name() = ‘pig’”> <i>this is a pig</i> </xsl:when> <xsl:otherwise> <i>this is not a pig</i> </xsl:otherwise> </xsl:choose>
xsl:value-of 显示选择节点或者属性的值
选择子节点price
<xsl:value-of select=”pets/*/price”/>
选择属性weight
<xsl:value-of select=”pets/*/@weight”/>
xsl:attribute 构造xml节点的属性
用来向节点添加属性,例如:
<font> <xsl:attribute name=”color”><xsl:value-of select=”pets/*/@color”/></xsl:attribute> </font>
将输出<font color=”red”></font>
xsl:apply-templates 应用模板
如果xml文件结构比较复杂,可以定义多个template,然后使用<xsl:apply-templates>标签应用模板,xsl:apply-templates 可以指定属性select=”xpath”来选择应用的模板,或者不指定select表示选择当前节点的模板。
XSL所有元素
| 元素 | 描述 | IE | N |
|---|---|---|---|
| apply-imports | 应用来自导入样式表中的模版规则。 | 6.0 | |
| apply-templates | 向当前元素或当前元素的子元素应用模板。 | 5.0 | 6.0 |
| attribute | 向元素添加属性。 | 5.0 | 6.0 |
| attribute-set | 创建命名的属性集。 | 6.0 | 6.0 |
| call-template | 调用一个指定的模板。 | 6.0 | 6.0 |
| choose | 与<when>以及<otherwise>协同使用,来表达多重条件测试。 | 5.0 | 6.0 |
| comment | 在结果树中创建注释节点。 | 5.0 | 6.0 |
| copy | 创建当前节点的一个备份(无子节点及属性)。 | 5.0 | 6.0 |
| copy-of | 创建当前节点的一个备份(带有子节点及属性)。 | 6.0 | 6.0 |
| decimal-format | 定义当通过 format-number() 函数把数字转换为字符串时,所要使用的字符和符号。 | 6.0 | |
| element | 在输出文档中创建一个元素节点。 | 5.0 | 6.0 |
| fallback | 假如处理器不支持某个XSLT元素,规定一段备用代码来运行。 | 6.0 | |
| for-each | 遍历指定的节点集中的每个节点。 | 5.0 | 6.0 |
| if | 包含一个模板,仅当某个指定的条件成立时应用此模板。 | 5.0 | 6.0 |
| import | 用于把一个样式表中的内容倒入另一个样式表中。 | 6.0 | 6.0 |
| include | 把一个样式表中的内容包含到另一个样式表中。 | 6.0 | 6.0 |
| key | 声明一个命名的键。 | 6.0 | 6.0 |
| message | 向输出写一条消息(用于错误报告)。 | 6.0 | 6.0 |
| namespace-alias | 把样式表中的命名空间替换为输出中不同的命名空间。 | 6.0 | |
| number | 测定当前节点的整数位置,并对数字进行格式化。 | 6.0 | 6.0 |
| otherwise | 规定 <choose> 元素的默认动作。 | 5.0 | 6.0 |
| output | 定义输出文档的格式。 | 6.0 | 6.0 |
| param | 声明一个局部或全局参数。 | 6.0 | 6.0 |
| preserve-space | 用于定义保留空白的元素。 | 6.0 | 6.0 |
| processing-instruction | 生成处理指令节点。 | 5.0 | 6.0 |
| sort | 对结果进行排序。 | 6.0 | 6.0 |
| strip-space | 定义应当删除空白字符的元素。 | 6.0 | 6.0 |
| stylesheet | 定义样式表的根元素。 | 5.0 | 6.0 |
| template | 当指定的节点被匹配时所应用的规则。 | 5.0 | 6.0 |
| text | 通过样式表生成文本节点。 | 5.0 | 6.0 |
| transform | 定义样式表的根元素。 | 6.0 | 6.0 |
| value-of | 提取选定节点的值。 | 5.0 | 6.0 |
| variable | 声明局部或者全局的变量。 | 6.0 | 6.0 |
| when | 规定 <choose> 元素的动作。 | 5.0 | 6.0 |
| with-param | 规定需被传入某个模板的参数的值。 | 6.0 | 6.0 |
XSL引入方式
IE浏览器支持直接在XML中直接引入XSL文件
<?xml-stylesheet type="text/xsl" href="icoreNested.xsl"?>
Chorme浏览器不能直接加载本地XSL文件
参考Can Chrome be made to perform an XSL transform on a local file

<html>
<head>
<script>
function loadXMLDoc(filename)
{
var progressBar = document.getElementById("p");
if (window.ActiveXObject)
{
xhttp = new ActiveXObject("Msxml2.XMLHTTP");
}
else
{
xhttp = new XMLHttpRequest();
}
xhttp.open("GET", filename, false);//Synchronous loadXMLDoc try {
xhttp.onprogress = function(pe) {
if(pe.lengthComputable) {
progressBar.max = pe.total
progressBar.value = pe.loaded
}
}
xhttp.onloadend = function(pe) {
progressBar.value = pe.loaded
}
} catch(err) {} // Helping IE11
xhttp.send();
return xhttp.responseXML;
} function displayResult()
{
xml = loadXMLDoc("cdcatalog.xml");
xsl = loadXMLDoc("cdcatalog.xsl");
// code for IE
if (window.ActiveXObject || xhttp.responseType == "msxml-document")
{
ex = xml.transformNode(xsl);
document.getElementById("example").innerHTML = ex;
}
// code for Chrome, Firefox, Opera, etc.
else if (document.implementation && document.implementation.createDocument)
{
xsltProcessor = new XSLTProcessor();
xsltProcessor.importStylesheet(xsl);
resultDocument = xsltProcessor.transformToFragment(xml, document);
document.getElementById("example").appendChild(resultDocument);
}
}
</script>
</head>
<body onload="displayResult()">
<h2>Content as Follow:</h2> <progress id=p style="width=100%"></progress> <div id="example" />
</body>
</html>
源码
参考
Can Chrome be made to perform an XSL transform on a local file?
XML通过XSL格式化的那点事(XML到自定义节点折叠显示)的更多相关文章
- xml和xsl配合使用实例
找到一个实际应用的例子,是英语统考打印准考证的实例,关于xml和xsl配合使用的. 下面看看xml文档 <?xml version='1.0' encoding='utf-8' ?> &l ...
- XML、XSL、XSLT、DTD、XSD的区别
前言: 在众神的努力之下,js已经可以跨出浏览器走向不同的领域了 也因为这个,对前端工程师的要求也不仅仅是会写写h5页面做交互.前端涉及的领域越来越广,对开发人员对素质能力要求越高. 以前因设备不同导 ...
- MyEclipse/Eclipse中XML文件的格式化配置
Eclipse中XML文件的格式化配置 MyEclipse: 这一步的配置是使格式化的效果为控件的每个属性配置占一行.进入 Window/Preferences,展开到 XML/XML Resourc ...
- eclipse的格式化规则(即format.xml文件).
eclipse的格式化规则(即format.xml文件) 下面是文件内容 <?xml version="1.0" encoding="UTF-8" sta ...
- XML XSD XSL区别与联系
XML: XML(Extensible Markup Language)即可扩展标记语言,它与HTML一样,都是SGML(Standard Generalized Markup Language,标准 ...
- htm,html,xhtml,xml,xsl,dhtml,shtm和shtml的区分
介绍一下htm,html,xhtml,xml,shtml的区分,以下内容来自百度后的知识整理. HTML和htm: HTML(Hypertext Markup Language)超文本传输语言,是ww ...
- 【解决方案】cvc-complex-type.2.4.a: Invalid content was found starting with element 'init-param'. One of '{"http://java.sun.com/xml/ns/javaee":run-as, "http://java.sun.com/xml/ns/javaee":security-role-r
[JAVA错误] cvc-complex-type.2.4.a: Invalid content was found starting with element 'init-param'. One o ...
- 项目中运行报错: Loading XML bean definitions from class path resource [applicationContext.xml]
记录一下: org.springframework.context.support.AbstractApplicationContext prepareRefresh Refreshing org.s ...
- 【转】循环递归遍历XML文档或按某要求遍历XML文档
<?xml version="1.0" encoding="UTF-8"?> <catalog> <cd> <titl ...
随机推荐
- Xamarin.Android之封装个简单的网络请求类
一.前言 回忆到上篇 <Xamarin.Android再体验之简单的登录Demo> 做登录时,用的是GET的请求,还用的是同步, 于是现在将其简单的改写,做了个简单的封装,包含基于Http ...
- 初探asp.net异步编程之await
终于毕业了,也顺利进入一家期望的旅游互联网公司.27号入职.放肆了一个多月没写代码,好方啊. 另外一下观点均主要针对于await. 请先看这段话,来自async in C# 5.0. 接下来几个月的 ...
- html5 前端图片处理(预览、压缩、缩放)
现在手机图片是越来越大了,上传图片流量耗费巨大.同时预览也是一个问题,所以利用HTML5 file和canvas来解决这个问题. var upload = { _o: null,//对象id _aut ...
- jQuery仿阿里云购买选择购买时间长度
效果:http://hovertree.com/texiao/jquery/61/ jQuery仿阿里云购买服务器选择时间长度,操作简单,只需点击所要选的时间段 代码: <!doctype ht ...
- js自动切换图片
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- What does "size" in int(size) of MySQL mean?
What does "size" in int(size) of MySQL mean? https://alexander.kirk.at/2007/08/24/what-doe ...
- Apache Lucene学习笔记
Hadoop概述 Apache lucene: 全球第一个开源的全文检索引擎工具包 完整的查询引擎和搜索引擎 部分文本分析引擎 开发人员在此基础建立完整的全文检索引擎 以下为转载:http://www ...
- 51nod 算法马拉松18 A 染色问题
染色问题 基准时间限制:1 秒 空间限制:10240 KB 分值: 40 一个n(3<=n<=100)个点的完全图,现在给出n,要求将每条边都染上一种颜色k(1<=k<=n), ...
- php实现设计模式之 适配器模式
<?php /* * 适配器模式:将一个类的接口转换成客户希望的另外一个接口.Adapter模式使得原来由于接口不兼容而不能一起工作的那些类可以一起工作(结构型模式) * * 一个源接口,不符合 ...
- 从零开始学 Java - 数据库连接池的选择 Druid
我先说说数据库连接 数据库大家都不陌生,从名字就能看出来它是「存放数据的仓库」,那我们怎么去「仓库」取东西呢?当然需要钥匙啦!这就是我们的数据库用户名.密码了,然后我们就可以打开门去任意的存取东西了. ...