top
Loading...
僅用XSL和ASP實現分頁功能(代碼)
---------------------------------
注意事項:
※本文代碼可能有一些多余部分未去掉,請在閱讀時忽略。
一些外部include進來的文件這里就不貼上來了。
※小乙寫xsl也不久,很多語句都不會使用,有些地方寫得比較羅嗦,
如果您有更好的分頁代碼,請多多拿來交流。
※適用于:用asp load進來xml代碼,
然后用此xsl文件進行分頁處理。
※[2001.2.19]
------------------------------------
asp文件大致結構:
<%@ Language=VBScript %>
<!-- #include file=include/lib.asp -->
<%  
cc=server.MapPath("trans.xml")
set source=server.CreateObject("msxml2.domdocument")
source.async=false
source.load(cc)

xslfile=server.MapPath("index.xsl")
set style=server.CreateObject("msxml2.domdocument")
style.async=false
style.load(xslfile)

'Response.write source.transformNode(style)
Response.write gb_html(source.transformNode(style))
Response.End  
%>
------------------------------------load進來的xml數據是這樣的:
<?xml version="1.0" encoding="GB2312" ?>  
<root>
<function>
<PO>里面的標簽在后面的xsl文件里被"<xsl:for-each>"</PO>
<PO>……………………</PO>
<PO>……………………</PO>
<PO>……………………</PO>
</function>
</root>


------------------------------------
xsl文件的內容:

<?xml version="1.0" encoding="GB2312"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:include href="include/ydzhongxin.xsl"/><!--嵌入頭模板,尾模板-->
<xsl:param name="yd">7</xsl:param><!--調用二級導航條所用參數 -->
<xsl:param name="page"><xsl:value-of select="count(//PO)"/></xsl:param>

<!-- 定義根模板-->
<xsl:template match="/">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"/>
<link rel="stylesheet" type="text/css" href="include/style.css"/>
<title>結果列表</title>
</head>
<body leftMargin="0" topMargin="0">
<xsl:call-template name="ydtitle"/>

<div align="center">
<xsl:apply-templates select="root/function"/>
<!--匹配function模板-->
</div>

<xsl:call-template name="end"/>
</body>
</html>
</xsl:template>



<!--定義function模板-->
<xsl:template match="function">
<!-- ---------------翻頁鏈接開始----------- -->
<xsl:variable name="pagesize">5</xsl:variable><!--是分頁參數 -->

<xsl:choose>
<xsl:when test="/root/session/page[text()!='']">
<!-- 進入一級choose的一個when條件分支!!!!!
-------------進入此分支,證明用戶已有翻頁操作-------------- -->
<xsl:variable name="page"><xsl:value-of select="/root/session/page"/></xsl:variable>
<table border="0" cellpadding="2" cellspacing="0" width="630">
<tr>
<td align="right">
<!-- 進入二級choose!!! -->
<xsl:choose>
<!-- ①id小于等于0的情況,顯示最后一頁。-->
<xsl:when test="$pid<1">
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count(//PO)"/></xsl:attribute>
[ 首 ]</a>
<a title="前一頁"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size*2"/></xsl:attribute>[ <<< ] </a>
<a title="后一頁">[ >>> ] </a>
<a>[ 尾 ]</a>
</xsl:when>
<!-- ②id位于[0~pagesize]之間的情況,前頁正常,后頁無。 -->
<xsl:when test="$pid<($size + 1) and $pid>0">
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count(//PO)"/></xsl:attribute>
[ 首 ]</a>
<a title="前一頁"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$pid+$size"/></xsl:attribute>[ <<< ] </a>
<a title="后一頁">[ >>> ] </a>
<a>[ 尾 ]</a>
</xsl:when>
<!-- ③id位于[pagesize~count]之間的情況,前頁無,后頁正常。 -->
<xsl:when test="$pid<count(//PO) and $pid>(count(//PO)-$size)">
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count(//PO)"/></xsl:attribute>
[ 首 ]</a>
<a title="前一頁"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count(//PO)"/></xsl:attribute>[ <<< ] </a>
<a title="后一頁"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$pid - $size"/></xsl:attribute>[ >>> ] </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
[ 尾 ]</a>
</xsl:when>

<!-- ④id等于count的情況,顯示首頁。 -->
<xsl:when test="$pid=count(//PO)">
<a>[ 首 ]</a>
<a title="前一頁">[ <<< ] </a>
<a title="后一頁"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count(//PO)-$size"/></xsl:attribute>[ >>> ] </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
[ 尾 ]</a>
</xsl:when>
<!-- ⑤id大于count的情況,顯示首頁。 -->
<xsl:when test="$pid>count(//PO)">
<a>[ 首 ]</a>
<a title="前一頁">[ <<< ] </a>
<a title="后一頁"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count(//PO)-$size"/></xsl:attribute>[ >>> ] </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
[ 尾 ]</a>
</xsl:when>

<!-- 正常情況 -->
<xsl:otherwise>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count(//PO)"/></xsl:attribute>
[ 首 ]</a>
<a title="前一頁"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$pid + $size"/></xsl:attribute>[ <<< ] </a>
<a title="后一頁"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$pid - $size"/></xsl:attribute>[ >>> ] </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
[ 尾 ]</a>
</xsl:otherwise>
</xsl:choose>
<!-- ---------------------------------------- -->
</td>
</tr>
</table><br/>
<!-- ---------遍歷符合要求的PO結點------------- -->
<xsl:for-each select="PO[position()<=$pid and position()>($pid - $size)]">
<xsl:sort select="PO_ID" order="descending" data-type="number"/>
<xsl:call-template name="PO"/>
<br/><br/><br/>
</xsl:for-each>
<!-- 退出一級choose的一個when條件分支!!!!! -->
</xsl:when>
<!-- ------------------用戶直接進入的狀態------------------ -->
<xsl:otherwise>
<!-- 進入一級choose的另一個when條件分支!!!!! -->
<table border="0" cellpadding="2" cellspacing="0" width="630">
<tr><td align="right">
<a>[ 首 ]</a>
<a title="前一頁">[ <<< ] </a>
<a title="后一頁"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$pid - $size"/></xsl:attribute>[ >>> ] </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
[ 尾 ]</a>
</td></tr>
</table><br/>
<xsl:for-each select="PO[position()<=$pid and position()>($pid - $size)]">
<xsl:sort select="PO_ID" order="descending" data-type="number"/>
<xsl:call-template name="PO"/>
<br/><br/><br/>
</xsl:for-each>
<!-- 退出一級choose的另一個when條件分支!!!!! -->
</xsl:otherwise>
</xsl:choose>
<!-- --------------翻頁鏈接到此結束----------- -->
<br/>
<xsl:if test="count(//PO)=0">

<div align="center"><b>
<img src="images/msg2.gif" align="absmiddle"/>
</b><font color="#CC0000" face="楷體CS" size="3"><b>
沒有符合當前條件的訂單</b></font>  
<a><xsl:attribute name="href">lkxx.asp?po_id=<xsl:value-of select="PO_ID"/></xsl:attribute></a>
</div>
><br/><br/>
<input type="button" value="重新輸入條件查詢" onclick="location.href='search.asp'"/>
</xsl:if>
</xsl:template>






<!-- ------------------------------------------>
<xsl:template name="PO">
<table border="1" cellpadding="2" cellspacing="0" width="100%">
<tr>  
<td nowrap="nowrap" width="70"> 號碼</td>
<td nowrap="nowrap" width="110"> 名稱</td>
<td nowrap="nowrap" width="110"> 日期</td>
<td nowrap="nowrap" width="110"> 人員</td>
</tr>
<tr>
<td nowrap="nowrap"> <xsl:value-of select="num"/></td>
<td nowrap="nowrap"> <xsl:value-of select="username"/></td>
<td nowrap="nowrap"> <xsl:value-of select="dt"/></td>
<td nowrap="nowrap"> <xsl:value-of select="men"/></td>
</tr>
</table>
</xsl:template>
</xsl:stylesheet>
北斗有巢氏 有巢氏北斗