加入收藏 | 设为首页 | 会员中心 | 我要投稿 安卓应用网 (https://www.0791zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > PHP > 正文

简化php模板页面中分页代码的解析

发布时间:2020-05-28 23:39:36 所属栏目:PHP 来源:互联网
导读:这篇文章主要是针对“使用模板的情况”写的,但是这种方法适合于任何的场合,在任何情况下都是一种比较好的解决方案



在使用模板的时候,会遇到这么一个问题:显示分页信息时操作麻烦,n多个模板都有分页块。
例如:
---共 20 条记录,当前 3/5 页 首页 上一页 下一页 尾页 GO-----
初遇到这个问题的道友,在考虑解决这个问题的时候好像都是在打php的主意,考虑怎么用php来实现,但是不管你是怎么设计都后设计成两种方案
1、用嵌套循环来实现
2、用n多个判断来搞
但是最终还是比较麻烦的,而且解析的时候是用的服务器端的资源。
不妨换个方法用javascript来代替你的php!!!!,这样即可减少php脚本的代码量,还可以把解析分页的工作交给客户端自己来作。不过javascript调试起来可能会比较麻烦。
最重要的是可以简化分页显示时,解析模板遇到的痛苦。
下面用一个支持pear的itx模板工具解析的模板.
其中和表示一个块,{recordcount}这种类似的字符串是变量。
----------------list.tpl---------------------
<div class="codetitle"><a style="CURSOR: pointer" data="74551" class="copybut" id="copybut74551" onclick="doCopy('code74551')"> 代码如下:<div class="codebody" id="code74551">
//其它的html代码
<TABLE border="0" cellpadding="0" cellspacing="0" width="100%">


<script src="images/page.js" src="images/page.js" language="javascript">
<script language="javascript">
recordCount = {recordcount};
show = {showinonepage}
pageCount = {pagecount};
pageNow = {page};
pageStr = "?page=page";
document.write(showListPage0(recordCount,show,pageCount,pageNow,pageStr));


//其它的html代码
--------------------page.js------------
//---------------共 20 条记录,当前 3/5 页 首页 上一页 下一页 尾页 GO-------------------
//recordCount = 20;
//show = 20
//pageCount = 5;
//pageNow = 3;
//pageStr = "?page=page";
//document.write(showListPage(recordCount,pageStr));
function showListPage0(recordCount,pageStr){
if(pageCount<1) pageCount =0;
if(pageNow<1) pageNow = 0;
str = '<form name="frmpage">共 '+recordCount+' 条记录,当前 '+pageNow+'/'+pageCount+' 页';
if(pageNow<=1)
str += " 首页 ";
else
str += " <A href=""+pageStr.replace("page",1)+"" href=""+pageStr.replace("page",1)+"">首页 ";
if(pageNow<=1)
str += " 上一页 ";
else
str += " <A href=""+pageStr.replace("page",(pageNow-1))+"" href=""+pageStr.replace("page",(pageNow-1))+"">上一页 ";
if(pageNow>=pageCount)
str += " 下一页 ";
else
str += " <A href=""+pageStr.replace("page",(pageNow+1))+"" href=""+pageStr.replace("page",(pageNow+1))+"">下一页 ";
if(pageNow>=pageCount)
str += " 尾页 ";
else
str += " <A href=""+pageStr.replace("page",pageCount)+"" href=""+pageStr.replace("page",pageCount)+"">尾页 ";
str += "跳到<input type="text" name="txtpage" size="3">页";
str += "<input type="button" value="GO" onclick="pagego0(document.frmpage.txtpage.value,"+pageNow+","+pageCount+",'"+pageStr+"')">";
return str;
}
function pagego0(pageGo,pageStr){
if(pageGo>=1 && pageGo<=pageCount && pageNow!=pageGo)
window.location = pageStr.replace("page",pageGo);
}

另外这种方法即使不用模板,也可以用,也一样是一种好的分页解决方案,只要将{recordcount}这种类似的字符串用变量的值替换就可以了。

(编辑:安卓应用网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读