快精灵印艺坊 您身边的文印专家
广州名片 深圳名片 会员卡 贵宾卡 印刷 设计教程
产品展示 在线订购 会员中心 产品模板 设计指南 在线编辑
 首页 名片设计   CorelDRAW   Illustrator   AuotoCAD   Painter   其他软件   Photoshop   Fireworks   Flash  

 » 彩色名片
 » PVC卡
 » 彩色磁性卡
 » 彩页/画册
 » 个性印务
 » 彩色不干胶
 » 明信片
   » 明信片
   » 彩色书签
   » 门挂
 » 其他产品与服务
   » 创业锦囊
   » 办公用品
     » 信封、信纸
     » 便签纸、斜面纸砖
     » 无碳复印纸
   » 海报
   » 大篇幅印刷
     » KT板
     » 海报
     » 横幅

仅用XSL和ASP实现分页功能

注重事项:
※本文代码可能有一些多余部分未去掉,请在阅读时忽略。
一些外部include进来的文件这里就不贴上来了。
※小乙写xsl也不久,很多语句都不会使用,有些地方写得比较罗嗦,
假如您有更好的分页代码,请多多拿来交流。
※适用于:用asp load进来xml代码,然后用此xsl文件进行分页处理。
--------------------------
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&lt;1">
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count
(//PO)"/></xsl:attribute>
&#91; 首 &#93;</a>
<a title="前一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of
select="$size*2"/></xsl:attribute>&#91; &#60;&#60;&#60; &#93; </a>
<a title="后一页">&#91; &#62;&#62;&#62; &#93; </a>
<a>&#91; 尾 &#93;</a>
</xsl:when>
<!-- ②id位于[0~pagesize]之间的情况,前页正常,后页无。 -->
<xsl:when test="$pid&lt;($size + 1) and $pid&gt;0">
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count
(//PO)"/></xsl:attribute>
&#91; 首 &#93;</a>
<a title="前一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of
select="$pid+$size"/></xsl:attribute>&#91; &#60;&#60;&#60; &#93; </a>
<a title="后一页">&#91; &#62;&#62;&#62; &#93; </a>
<a>&#91; 尾 &#93;</a>
</xsl:when>
<!-- ③id位于[pagesize~count]之间的情况,前页无,后页正常。 -->
<xsl:when test="$pid&lt;count(//PO) and $pid&gt;(count(//PO)-$size)">
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count
(//PO)"/></xsl:attribute>
&#91; 首 &#93;</a>
<a title="前一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count
(//PO)"/></xsl:attribute>&#91; &#60;&#60;&#60; &#93; </a>
<a title="后一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$pid -
$size"/></xsl:attribute>&#91; &#62;&#62;&#62; &#93; </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
&#91; 尾 &#93;</a>
</xsl:when>

<!-- ④id等于count的情况,显示首页。 -->
<xsl:when test="$pid=count(//PO)">
<a>&#91; 首 &#93;</a>
<a title="前一页">&#91; &#60;&#60;&#60; &#93; </a>
<a title="后一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count
(//PO)-$size"/></xsl:attribute>&#91; &#62;&#62;&#62; &#93; </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
&#91; 尾 &#93;</a>
</xsl:when>
<!-- ⑤id大于count的情况,显示首页。 -->
<xsl:when test="$pid&gt;count(//PO)">
<a>&#91; 首 &#93;</a>
<a title="前一页">&#91; &#60;&#60;&#60; &#93; </a>
<a title="后一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count
(//PO)-$size"/></xsl:attribute>&#91; &#62;&#62;&#62; &#93; </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
&#91; 尾 &#93;</a>
</xsl:when>

<!-- 正常情况 -->
<xsl:otherwise>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="count
(//PO)"/></xsl:attribute>
&#91; 首 &#93;</a>
<a title="前一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$pid +
$size"/></xsl:attribute>&#91; &#60;&#60;&#60; &#93; </a>
<a title="后一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$pid -
$size"/></xsl:attribute>&#91; &#62;&#62;&#62; &#93; </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
&#91; 尾 &#93;</a>
</xsl:otherwise>
</xsl:choose>
<!-- ---------------------------- -->
</td>
</tr>
</table><br/>
<!-- ---------遍历符合要求的PO结点-------- -->
<xsl:for-each select="PO[position()&lt;=$pid and position()&gt;($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>&#91; 首 &#93;</a>
<a title="前一页">&#91; &#60;&#60;&#60; &#93; </a>
<a title="后一页"><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$pid -
$size"/></xsl:attribute>&#91; &#62;&#62;&#62; &#93; </a>
<a><xsl:attribute name="href">search_jieguo.asp?id=<xsl:value-of select="$size"/></xsl:attribute>
&#91; 尾 &#93;</a>
</td></tr>
</table><br/>
<xsl:for-each select="PO[position()&lt;=$pid and position()&gt;($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"/>&#127;
</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"> &#127;号码</td>
<td nowrap="nowrap" width="110"> &#127;名称</td>
<td nowrap="nowrap" width="110"> &#127;日期</td>
<td nowrap="nowrap" width="110"> &#127;人员</td>
</tr>
<tr>
<td nowrap="nowrap"> &#127;<xsl:value-of select="num"/></td>
<td nowrap="nowrap"> &#127;<xsl:value-of select="username"/></td>
<td nowrap="nowrap"> &#127;<xsl:value-of select="dt"/></td>
<td nowrap="nowrap"> &#127;<xsl:value-of select="men"/></td>
</tr>
</table>
</xsl:template>
</xsl:stylesheet>
返回类别: 教程
上一教程: 利用FSO取得BMP,JPG,PNG,GIF文件信息
下一教程: 教你一次下载网页中的所有资源

您可以阅读与"仅用XSL和ASP实现分页功能"相关的教程:
· 用ASP实现分页的源码
· 在ASP中,用JSCRIPT脚本实现分页的另类办法
· 用ASP实现分页显示的具体讲解
· ASP中实现分页显示的七种武器
· ASP+FSO+框架实现ASP生成HTM并分页的方式
    微笑服务 优质保证 索取样品