欢迎光临
我们一直在努力

仅用xsl和asp实现分页功能。[源码]

建站超值云服务器,限时71元/月

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)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 仅用xsl和asp实现分页功能。[源码]
分享到: 更多 (0)

相关推荐

  • 暂无文章