极品桌面极品CG红豆SKIN
加载中...
爆笑网文网页制作精妙网文冲浪宝典软件教学操作系统安全防御小说连载

ASP技术

ASP.Net

网页技术

数据库类

网站相关

XML

JSP编程

建站经验

PHP技术

MS SQL

asp标示及命令集合
Vbscript类型转换
无组件上传文字与图片至数
几种常用的表单输入判断
数据分页方法新思路,速度
在ASP中使用SQL语句
在ASP中使用SQL语句
在ASP中使用SQL语句
利用stream直接下载
有关ASP的一些常见问题
VBScript函数
一个实用的ASP分页函数
SQL四条最基本的数据操
按钮链接乾坤大挪移
将ACCESS转化成SQ
当前位置:极品网文-> 网页制作-> ASP技术-> 浏览文章[双击自动滚屏]
仅用XSL和ASP实现分页功能(代码)
作者:小乙 来源:chinaasp 添加时间:2002年12月18日
---------------------------------

注意事项:

※本文代码可能有一些多余部分未去掉,请在阅读时忽略。

 一些外部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:&#118alue-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:&#118alue-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:&#118alue-of select="count(//PO)"/></xsl:attribute>

[ 首 ]</a>

    <a title="前一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-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:&#118alue-of select="count(//PO)"/></xsl:attribute>

[ 首 ]</a>

    <a title="前一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-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:&#118alue-of select="count(//PO)"/></xsl:attribute>

[ 首 ]</a>

    <a title="前一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-of select="count(//PO)"/></xsl:attribute>[ <<< ] </a>

    <a title="后一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-of select="$pid - $size"/></xsl:attribute>[ >>> ] </a>

    <a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-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:&#118alue-of select="count(//PO)-$size"/></xsl:attribute>[ >>> ] </a>

    <a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-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:&#118alue-of select="count(//PO)-$size"/></xsl:attribute>[ >>> ] </a>

    <a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-of select="$size"/></xsl:attribute>

[ 尾 ]</a>

    </xsl:when>



    <!-- 正常情况 -->

    <xsl:otherwise>

    <a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-of select="count(//PO)"/></xsl:attribute>

[ 首 ]</a>

    <a title="前一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-of select="$pid + $size"/></xsl:attribute>[ <<< ] </a>

    <a title="后一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-of select="$pid - $size"/></xsl:attribute>[ >>> ] </a>

    <a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-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:&#118alue-of select="$pid - $size"/></xsl:attribute>[ >>> ] </a>

<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:&#118alue-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:&#118alue-of select="PO_ID"/></xsl:attribute></a>

  </div>

><br/><br/>

<input type="button" &#118alue="重新输入条件查询" &#111nclick="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:&#118alue-of select="num"/></td>

<td nowrap="nowrap"> <xsl:&#118alue-of select="username"/></td>

<td nowrap="nowrap"> <xsl:&#118alue-of select="dt"/></td>

<td nowrap="nowrap"> <xsl:&#118alue-of select="men"/></td>

  </tr>

 </table>

</xsl:template>

</xsl:stylesheet>

...
返回页面顶端
[返回上一页] [打印本文] [加入收藏]
页面最后更新时间:2009年2月4日
上一篇:创建复杂交互效果(Rollovers)
下一篇:169proxy服务器设置大全
相关文章