xml数据岛的数据格式:
<?xml version="1.0" encoding="GBK"?>
<list>
<ExchangeDataInfo>
<id>1e4929642d904b6eba7db731b13ef960</id>
<name>abc</name>
<date>20120710 14:50:22.0 CST</date>
<updateDate>20120710 14:50:22.0 CST</updateDate>
<size>4168</size>
<desc>本文件是用于数据文件管理组件中运行测试用例使用</desc>
<keyWords>
<string>白图片</string>
<string>数据管理</string>
<string>上传</string>
<string>测试</string>
</keyWords>
<exchangeInfo>
<taskINSID>1</taskINSID>
<taskSourceIP>172.16.10.30</taskSourceIP>
<exchangeNodeID>1</exchangeNodeID>
<taskType>EXCHANGENODEDownLOAD</taskType>
<exchangeDataType>SPATIALDATA</exchangeDataType>
<exchangeFileType>SHAPE</exchangeFileType>
<isValid>true</isValid>
<sequenceEnd>20120716 16:41:26.453 CST</sequenceEnd>
<downLoadTimes>0</downLoadTimes>
<orderIndex>1</orderIndex>
</exchangeInfo>
</ExchangeDataInfo>
<ExchangeDataInfo>
<id>0c091601eb5c474785ee046c358fa0ac</id>
<name>又是白图片</name>
<date>20120708 10:20:22.0 CST</date>
<updateDate>20120708 10:20:22.0 CST</updateDate>
<size>4168</size>
<desc>本文件是用于数据文件管理组件中运行测试用例使用</desc>
<keyWords>
<string>又是白图片</string>
<string>数据管理</string>
<string>下载</string>
<string>测试</string>
</keyWords>
<exchangeInfo>
<taskINSID>2</taskINSID>
<taskSourceIP>172.16.10.30</taskSourceIP>
<exchangeNodeID>1</exchangeNodeID>
<taskType>EXCHANGENODEDOWNLOAD</taskType>
<exchangeDataType>SPATIALDATA</exchangeDataType>
<exchangeFileType>SHAPE</exchangeFileType>
<isValid>true</isValid>
<sequenceEnd>20120716 16:41:26.872 CST</sequenceEnd>
<downLoadTimes>2</downLoadTimes>
<orderIndex>2</orderIndex>
</exchangeInfo>
</ExchangeDataInfo>
</list>
XSL文件内容 :xsl就是xml的样式(css)
<?xml version="1.0" encoding="GBK"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:wfs="http://www.opengis.net/wfs">
<!-- 可以删除 作用不明-->
<xsl:output method="xml" omit-xml-declaration="no" indent="no" />
<!-- 可以删除 作用不明-->
<xsl:param name="enableServiceNode"></xsl:param>
<!--模板与xml数据岛匹配的节点名称,如果是/,则表示根节点,当前为list -->
<xsl:template match="list">
<!-- element是输出或者说返回给用户的xml,name表示节点名称,那么这样就会输出一个rows的节点-->
<xsl:element name="rows">
<!-- xsl的for-each用于循环xml数据岛中的数据-->
<xsl:for-each select="ExchangeDataInfo">
<!-- 输出一个row几点-->
<xsl:element name="row">
<!-- 给row节点添加一个id属性,id属性的值等于xml数据岛中的id节点的值-->
<xsl:attribute name="id">
<!-- 获取xml数据岛中id节点的值-->
<xsl:value-of select="id" />
</xsl:attribute>
<!--输出一个cell节点 -->
<xsl:element name="cell">
<!-- 获取xml数据岛中id节点的值-->
<xsl:value-of select="id" />
</xsl:element>
<!--输出一个cell节点-->
<xsl:element name="cell">
<!--输入固定的字符,不从xml数据岛中读取数据-->
images/RAR.png
</xsl:element>
<xsl:element name="cell">
<!--xsl的choose用法:when,otherwise-->
<xsl:choose>
<!-- 语法表示:如果xml数据岛中的name属性的长度大于100
string-length()方法用于获取字符串的长度
test="..."用于判断
-->
<xsl:when test="string-length(name) > 100">
<!-- 给返回的数据前添加b标签,实现加粗效果,使用substring(aString,start,end)截取字符串-->
<b> <xsl:value-of select="substring(name,0,100)" />...zip</b>
</xsl:when>
<!--否则的话,执行这段代码-->
<xsl:otherwise>
<!--直接输出xml数据岛中的name属性,并追加b标签-->
<b><xsl:value-of select="name" /></b>
</xsl:otherwise>
</xsl:choose>
</xsl:element>
<xsl:element name="cell">
<xsl:value-of select="size" />
</xsl:element>
<xsl:element name="cell">
<xsl:value-of select="date" />
</xsl:element>
<xsl:element name="cell">
<!--xml数据岛是多层次的节点的使用方法:使用/号,例如:parent/son -->
<xsl:if test="exchangeInfo/taskType = 'CENTERUPLOAD'">
<!--输出图片-->
<img src="images/up.png"/>
</xsl:if>
<xsl:if test="exchangeInfo/taskType = 'CENTERDOWNLOAD'">
<img src="images/down.png"/>
</xsl:if>
<xsl:if test="exchangeInfo/taskType = 'EXCHANGENODEUPLOAD'">
<img src="images/up.png"/>
</xsl:if>
<xsl:if test="exchangeInfo/taskType = 'EXCHANGENODEDOWNLOAD'">
<img src="images/down.png"/>
</xsl:if>
</xsl:element>
<xsl:element name="cell">
<!--添加js脚本的响应时间:通过拼凑span标签,并添加onclick实现-->
<span href="#" onclick="DataManager.downData('<xsl:value-of select="id" />')"><img style="margin:0px;padding:0px" src="images/download0.png"/></span>
<span href="#" onclick="DataManager.detailData('<xsl:value-of select="id" />')"><img style="margin:0px;padding:0px;position:relative;left:-3px;" src="images/detail0.png"/></span>
<span href="#" onclick="DataManager.deleteData('<xsl:value-of select="id" />')"><img style="margin:0px;padding:0px;position:relative;left:-6px;" src="images/del.png"/></span>
</xsl:element>
</xsl:element>
</xsl:for-each>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
显示结果见附件:使用dhtmlxgrid的显示结果
xsl有自己的函数库,详见:http://blog.csdn.net/ccsdba/article/details/1635050 和 http://blog.163.com/chenyunpei_studio@126/blog/static/36578255200762882452192/
xsl也允许自定义函数,详见:http://hi.baidu.com/godghdai/blog/item/e8955066580ff62fab184ce9.html
但是,自定义函数在j2ee应用中,会碰到安全设置不允许的问题,所以一直没有实质性的效果。
下面是自己的尝试
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt"
xmlns:user="http://supermap.com/">
<msxsl:script language="javascript" implements-prefix="user">
function GetName(node) {
return (node+"aaaaaaaaaaaaaaaaf").substr(1,8);
}
]]>
</msxsl:script>
<xsl:template match="list">
<xsl:element name="cell"><!--自定义函数的使用方法-->
<b><xsl:value-of select="user:GetName(name)" /></b>
<xsl:if test="string-length(name) > 3">
<b><xsl:value-of select="substring(name,0,15)" />...</b>
</xsl:if>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
这种写法,在jsp页面中会提示:页面安全设置不允许在此使用函数 这样类似的提示,最终导致不能返回正常的记过。
<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:msxsl="urn:schemas-microsoft-com:xslt"
xmlns:user ="http://www.mycompany.org/ns/function"
xmlns:lxslt="http://xml.apache.org/xslt"
exclude-result-prefixes="user">
<lxslt:component prefix="user" elements="rules" functions="GetName">
<msxsl:script language="javascript" implements-prefix="user">
<![CDATA[
function GetName(node) {
return (node+"aaaaaaaaaaaaaaaaf").substr(1,8);
}
]]>
</msxsl:script>
</lxslt:component>
<xsl:template match="list">
....
</xsl:template>
</xsl:stylesheet>
这种写法,绕开了安全设置的提示,但是会提示:命名空间不包含任何函数的提示,最终还是失败。
xsl中的除法:div方法
xsl中的数字格式化:format-number(anumber,'0.00');//表示保留两位小数
<xsl:choose>
<xsl:when test="number(size) > (1024*1024*1024)">
<xsl:value-of select="format-number(number(size) div (1024*1024*1024),'.00')" />G
</xsl:when>
<xsl:when test="number(size) > (1024*1024)">
<xsl:value-of select="format-number(number(size) div (1024*1024),'.00')" />M
</xsl:when>
<xsl:when test="number(size) > 1024">
<xsl:value-of select="format-number(number(size) div 1024,'.00')" />k
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="size" />
</xsl:otherwise>
</xsl:choose>
//dhtmlgrid的使用:
//listServiceURL = "testdata/dataexchange1.xml";//TODO 测试数据
mygrid.parse(TransFormUtil.transForm(listServiceURL,"xslt/dataexchange.xsl",null,3));
Transform.js:
/*-----------------------通用xsl转换类(静态类)-----------------*/
/*-----------------------版本:V1.0------------------*/
/*-----------------------作者:songxw-----------------*/
///<sumary>
/// xsl转换类--用于适应firefox以及IE各版本
///</sumary>
TransFormUtil=new function()
{
/// <summary>
/// 转换过程
/// </summary>
///<params name="xml">要转换的xml源</params>
///<params name="xsl">执行转换的式xsl模板</params>
///<params name="params">转换参数:json格式</params>
///<params name="resouceType">数据源类型:0表示xml为string/xsl为string,1表示xml为string/xsl为file,2表示xml为string/xsl为file,3表示xml为file/xsl为file</params>
/// <returns>执行转换后的html结果</returns>
this.transForm=function(xml,xsl,params,resouceType)
{
//获取浏览器版本信息
var browser=getBrowser();
var formatHtml="";
var xmlDom=BrowserAdepter.getDomDocument();
xmlDom.async = false;
switch(resouceType)
{
//从string中加载数据源
case 0:
case 1:
xmlDom=BrowserAdepter.loadXML(xml);
break;
//从file中加载数据源
case 2:
case 3:
xmlDom=BrowserAdepter.load(xml);
break;
}
//必须使用线程安全的Dom对象
var xslDom =BrowserAdepter.createFreeThreadedDocument();
xslDom.async = false;
switch(resouceType)
{
//从string中加载数据源
case 0:
case 2:
xslDom=BrowserAdepter.loadXML(xsl);
break;
//从file中加载数据源
case 1:
case 3:
if(typeof xslDom.load !='undefined'){
xslDom.load(xsl);
}
else{
xslDom=BrowserAdepter.load(xsl);
}
break;
}
if(BrowserAdepter.getXml(xmlDom)=="") return "";
var xslTemplate =BrowserAdepter.createXSLTemplate();
//适用于IE
if(browser.isIE)
{
xslTemplate.stylesheet =xslDom;
// 创建XslProcessor对象
var xslProcessor = xslTemplate.createProcessor();
xslProcessor.input = xmlDom;
//转换参数
if(params!=null && params!=undefined)
{
for(var key in params)
{
xslProcessor.addParameter(key,eval("params."+key));
}
}
// 执行XSLT转换
xslProcessor.transform();
formatHtml=xslProcessor.output;
}
//适用于firefox
else
{
xslTemplate.importStylesheet(xslDom);
//转换参数
if(params!=null && params!=undefined)
{
var value="";
for(var key in params)
{
value=eval("params."+key);
xslTemplate.setParameter(null,key,value);
}
}
var result = xslTemplate.transformToFragment(xmlDom,document);
var xmls = new XMLSerializer();
formatHtml=xmls.serializeToString(result);
}
formatHtml=formatHtml;
xmlDom=null;
xslDom=null;
xslTemplate=null;
return formatHtml.replace("<?xml version=\"1.0\"?>","");
};
}
xsl大写转换成小写:translate(str,'A...Z','a...z')
<!--定义变量-->
<xsl:variable name="uppercase">ABCDEFGHIJKLMNOPQRSTUVWXYZ</xsl:variable>
<xsl:variable name="lowercase">abcdefghijklmnopqrstuvwxyz</xsl:variable>
<!--大小写转换-->
<td class="title">策略类型</td>
<td class="value"><xsl:value-of select="translate(strategyType,$uppercase,$lowercase)"/></td>
xsl中进行非空判断
<xsl:if test="processInfo !=null">
<xsl:value-of select="processInfo"/>
</xsl:if>
- 大小: 8.1 KB
分享到:
相关推荐
微软Dhtml网页开发控件帮助文档(翻译)微软Dhtml网页开发控件帮助文档(翻译)
在IT领域,DHTML、CSS2、JavaScript和XML是构建现代网页和应用程序的重要技术。这些技术的结合使得开发者能够创建出交互性强、表现丰富的网络体验。 **DHTML(Dynamic HTML)** 是一种在HTML文档中引入动态效果的...
HTML,DHTML,VRML,XML功能分析与比较研究 HTML,DHTML,VRML,XML功能分析与比较研究
XML(eXtensible Markup Language)则是一种可扩展标记语言,它主要用于存储和传输数据,而不是用于显示数据。XML的设计宗旨是传输和存储数据,而不是显示数据,因此它的结构更加严格和自描述性,允许用户自定义标签...
DHTML 手册通常会涵盖这些基础知识,以及更高级的话题,如框架库(如jQuery)、AJAX使用、响应式设计、跨浏览器兼容性等。通过深入学习和实践DHTML,开发者能够创建更加丰富、互动的网页应用,提升用户与网页的交互...
本篇将深入探讨基于DHTML+AJAX实现的Menu类库scripts代码实例,这一技术主要用于构建动态、交互式的网页菜单系统。DHTML(Dynamic HTML)是一种结合了HTML、CSS、JavaScript以及DOM(Document Object Model)的技术...
**DHTML XML 实用手册(标识 语法 函数 方法 介绍)** DHTML(Dynamic HTML)和XML(Extensible Markup Language)是Web开发中的核心技术,它们共同为创建动态、交互性和数据驱动的网页提供了强大的支持。 DHTML是...
JavaScript通常用于操作DOM,添加、删除或修改页面元素,从而实现DHTML的效果。 CSS在DHTML中扮演着重要角色,它负责定义元素的外观和布局。通过选择器和规则,我们可以改变HTML元素的颜色、大小、位置等属性。CSS3...
通过XMLDOM,开发者可以使用JavaScript或其他支持DOM的编程语言来读取、修改、创建和更新XML文档。XMLDOM提供了诸如节点操作(如创建、删除和移动节点)、查找特定节点、以及设置和获取属性值等功能,使得处理XML...
本Dhtml手册.chm文件是一个关于DHTML的综合参考资料,对于想要深入了解和学习DHTML的开发者来说,是一份宝贵的资源。 1. **HTML基础**:DHTML建立在HTML的基础上,HTML是超文本标记语言,用于创建网页结构。DHTML...
在这个名为“DHTML用户界面,使用方便”的主题中,我们主要探讨如何利用DHTML技术构建易于使用的界面。 首先,DHTML的核心在于其动态特性。通过JavaScript,我们可以编写脚本来改变HTML元素的位置、样式和内容,而...
这些组件通常基于DHTML技术,利用JavaScript和CSS实现丰富的交互效果和动态功能。 DHTMLX Suite的使用通常涉及以下几个步骤: 1. **引入库**:在HTML文件中添加DHTMLX Suite的JavaScript和CSS引用。 2. **初始化...
【标题】:基于XML的单元自测应用设计实现 ...总的来说,基于XML的单元自测应用巧妙地结合了XML、DOM、XSL、JavaScript和DHTML技术,构建了一个高效、适应性强且互动的在线测试系统,有助于提升网络课程的教学效果。
2. **样式表**:使用 CSS 或 XSL 来格式化 XML 内容,使其在浏览器中呈现为友好的界面。 ### 第六章:微软的 XML 解释器 微软开发了自己的 XML 解释器,支持在 Windows 系统上处理 XML 文档。这包括了: 1. **...
- DHTML通过DOM增强了客户端交互性,允许使用脚本动态修改页面内容。 - XML与HTML结合,为开发者提供了构建富Web应用的新方法。开发者可以通过脚本展示和处理基于XML的数据,同时利用XSLT或直接DOM操作呈现不同...
DHTML常用标签的使用说明,非常详细。DHTML常用标签的使用说明,非常详细。DHTML常用标签的使用说明,非常详细。DHTML常用标签的使用说明,非常详细DHTML常用标签的使用说明,非常详细DHTML常用标签的使用说明,非常...
**DHTML(Dynamic HTML)**是一种用于创建交互式和动态网页的技术,它结合了HTML、CSS、JavaScript以及DOM(文档对象模型)等技术,使得网页不仅具有静态展示内容的能力,还能实现动态效果和用户交互。 **HTML...
**DHTML(Dynamic HTML)** 是一种在网页上...随着Web技术的不断发展,DHTML作为早期实现页面动态化的技术,虽然现代Web开发更多倾向于使用框架如React、Vue等,但其基本原理仍对理解前端动态渲染有着重要的参考价值。