XML通过XSL格式化的那点事(XML到自定义节点折叠显示)

 

引言

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

过程中遇到的问题解决方法

参看XLT格式化XML那点事(二)

效果图

image

 

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语句)注意小于号大于号要分别用&lt;和&gt;替代

<xsl:if test=”@weight &lt; 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所有元素

元素描述IEN
apply-imports应用来自导入样式表中的模版规则。6.0 
apply-templates向当前元素或当前元素的子元素应用模板。5.06.0
attribute向元素添加属性。5.06.0
attribute-set创建命名的属性集。6.06.0
call-template调用一个指定的模板。6.06.0
choose与<when>以及<otherwise>协同使用,来表达多重条件测试。5.06.0
comment在结果树中创建注释节点。5.06.0
copy创建当前节点的一个备份(无子节点及属性)。5.06.0
copy-of创建当前节点的一个备份(带有子节点及属性)。6.06.0
decimal-format定义当通过 format-number() 函数把数字转换为字符串时,所要使用的字符和符号。6.0 
element在输出文档中创建一个元素节点。5.06.0
fallback假如处理器不支持某个XSLT元素,规定一段备用代码来运行。6.0 
for-each遍历指定的节点集中的每个节点。5.06.0
if包含一个模板,仅当某个指定的条件成立时应用此模板。5.06.0
import用于把一个样式表中的内容倒入另一个样式表中。6.06.0
include把一个样式表中的内容包含到另一个样式表中。6.06.0
key声明一个命名的键。6.06.0
message向输出写一条消息(用于错误报告)。6.06.0
namespace-alias把样式表中的命名空间替换为输出中不同的命名空间。6.0 
number测定当前节点的整数位置,并对数字进行格式化。6.06.0
otherwise规定 <choose> 元素的默认动作。5.06.0
output定义输出文档的格式。6.06.0
param声明一个局部或全局参数。6.06.0
preserve-space用于定义保留空白的元素。6.06.0
processing-instruction生成处理指令节点。5.06.0
sort对结果进行排序。6.06.0
strip-space定义应当删除空白字符的元素。6.06.0
stylesheet定义样式表的根元素。5.06.0
template当指定的节点被匹配时所应用的规则。5.06.0
text通过样式表生成文本节点。5.06.0
transform定义样式表的根元素。6.06.0
value-of提取选定节点的值。5.06.0
variable声明局部或者全局的变量。6.06.0
when规定 <choose> 元素的动作。5.06.0
with-param规定需被传入某个模板的参数的值。6.06.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

 image

 

<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 οnlοad="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?

嵌套的可折叠块

转载于:https://www.cnblogs.com/HQFZ/p/4795310.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值