-- 作者:admin
-- 发布时间:3/9/2004 11:37:00 PM
-- [转帖]在XSLT实现按日期排序
转载自:http://www.csdn.net/Develop/Read_Article.asp?Id=24853 在XSLT实现按日期排序 作者:孟宪会 出自:【孟宪会之精彩世界】 发布日期:2004年2月21日 11点47分56秒 -------------------------------------------------------------------------------- 我们在使用XSLT进行XML转换的时候,经常遇到按XML日期类型的数据进行排序的情况,按照默认的排序规则,很难实现正确的排序效果。虽然最新的MsXML3 SP4提供了3种数据类型的排序方式: <xsl:sort select = string-expression data-type = { "text" | "number" | Qname } order = { "ascending" | "descending" } /> 但好像仍不能满足我们的需要,下面我们就介绍日期类型数据的排序方法。我们的排序方法是基于下面语句的返回值为true的理论的: <script language="JavaScript"> alert(Date.parse("2004/08/09")==Date.parse("2004/8/9")) </script> 好了,下面就是我们的xsl文件: SortXML.xsl <?xml version="1.0" encoding="gb2312"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-microsoft-com:xslt" xmlns:user="http://dotnet.aspx.cc/" exclude-result-prefixes="msxsl user"> <msxsl:script language="JavaScript" implements-prefix="user"> function xmlDateTime(nodelist) { return Date.parse(nodelist.replace(/-/g,"/")); } </msxsl:script> <xsl:output omit-xml-declaration="yes"/> <xsl:template match="/"> <xsl:call-template name="ItemList"/> </xsl:template> <xsl:template name="ItemList"> <table bgcolor="snow" border="1" cellpadding="5" cellspacing="2" borderColor="darkorange" style="font-size:9pt"> <thead> <tr bgcolor=""> <th width="50%">标题</th> <th width="50%">修改时间</th> </tr> </thead> <tbody> <xsl:for-each select="/multistatus/response"> <xsl:sort order="descending" select="user:xmlDateTime(string(getlastmodified))" data-type="number"/> <tr> <td> <a href="{href}" target="_blank"> <xsl:value-of select="Title"/> </a> </td> <td> <xsl:value-of select="getlastmodified"/> </td> </tr> </xsl:for-each> </tbody> </table> </xsl:template> </xsl:stylesheet> SortXML.xml 查看转换结果 http://sz.luohuedu.net/xml/SortXML.xml 本地演示:http://bbs.xml.org.cn/demo/SortXML.xml [此贴子已经被作者于2004-3-10 0:51:40编辑过]
|