首页下载分类最新更新汉化补丁下载排行国产软件国外软件注册破解资讯中心游戏娱乐
78软件站 - 首页
文章搜索: 分类 关键字
您的位置:首页网络编程ASP技术 → 仅用XSL和ASP实现分页功能(代码)
仅用XSL和ASP实现分页功能(代码)
日期:2002-12-18 7:46:05 人气:311     [ ]
---------------------------------
注意事项:
※本文代码可能有一些多余部分未去掉,请在阅读时忽略。
 一些外部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>
出处:本站原创 作者:本站原创
评论人 评论内容摘要(共 0 条,查看完整内容) 得分 0 发表时间
 热点文章
·Windows XP中快速转换FAT32至NTFS
·Windows 98全方位优化
·直接用WIN2000自带的NAT的实现端口映射的方法
·Ghost 2003成功克隆Windows XP
·全面提速Windows XP
·Windows XP优化技巧
·windows XP 系统服务“关闭”详细列表,释放N多内..
·Windows XP关机技巧二则
·Adobe Photoshop 鲜为人知的75个技巧[酷]
·给Windows XP减减肥
 推荐文章
·用好你的Windows安全模式
·想慢都不行:WinXP急速启动最新技巧
·各种ADSL路由设置
·解决 Windows XP_SP2 验证码无法显示的补丁!
·Windows Server 2003在线更新的补丁!
78软件站 版权所有 Copyright© 2003-2008 Www.78soft.COM, All Rights Reserved. Powered By 78软件站 鄂ICP备05000648号