鸿 网 互 联 www.68idc.cn

当前位置 : 服务器租用 > cms安装教程 > phpcms > >

phpcms自定义分页

来源:互联网 作者:佚名 时间:2015-08-11 10:05
在global.func.php中找到分页函数 function pages($num, $curr_page, $perpage = 20, $urlrule = '', $array = array(),$setpages = 10) {.......} 复制一下改个名例如叫 function test_pages($num, $curr_page, $perpage = 20, $urlrule = '', $array = arr

在global.func.php中找到分页函数
function pages($num, $curr_page, $perpage = 20, $urlrule = '', $array = array(),$setpages = 10) {.......}
复制一下改个名例如叫
function test_pages($num, $curr_page, $perpage = 20, $urlrule = '', $array = array(),$setpages = 10) {.......}

 1 /**
 2  * 测试分页函数
 3  *
 4  * @param $num 信息总数
 5  * @param $curr_page 当前分页
 6  * @param $perpage 每页显示数
 7  * @param $urlrule URL规则
 8  * @param $array 需要传递的数组,用于增加额外的方法
 9  * @return 分页
10  */
11 function test_pages($num, $curr_page, $perpage = 20, $urlrule = '', $array = array(),$setpages = 10) {
12     if(defined('URLRULE') && $urlrule == '') {
13         $urlrule = URLRULE;
14         $array = $GLOBALS['URL_ARRAY'];
15     } elseif($urlrule == '') {
16         $urlrule = url_par('page={$page}');
17     }
18     $multipage = '';
19     if($num > $perpage) {
20         $page = $setpages+1;
21         $offset = ceil($setpages/2-1);
22         $pages = ceil($num / $perpage);
23         if (defined('IN_ADMIN') && !defined('PAGES')) define('PAGES', $pages);
24         $from = $curr_page - $offset;
25         $to = $curr_page + $offset;
26         $more = 0;
27         if($page >= $pages) {
28             $from = 2;
29             $to = $pages-1;
30         } else {
31             if($from <= 1) {
32                 $to = $page-1;
33                 $from = 2;
34             }  elseif($to >= $pages) {
35                 $from = $pages-($page-2);
36                 $to = $pages-1;
37             }
38             $more = 1;
39         }

//从这里网上是分页的核心部分,不能改变往下就是一些分页样式了,自己按照形式来把,这是我写的比较简单的分页样式后面有图
//并且这里我比较懒的没有用语言包,有兴趣的朋友可以把所有的中文放到语言包中
//变量解释  $pages == 总页数      $curr_page == 当前页    pageurl($urlrule, 第n页, $array)函数用于生成url ,$urlrule和$array默认就行了

 $multipage .= '总共:<font color="#ff0000">'. $pages.'</font>页, <font color="#ff0000">'. $num .'</font>篇文章, ';
                $multipage .= '当前页:<font color="#ff0000"> '. $curr_page .' </font>';
                if($curr_page>0){
                    if($curr_page==1){
                        $multipage .= '<a href="'. pageurl($urlrule, $curr_page+1, $array;
                        $multipage .= '<a href="'. pageurl($urlrule, $pages, $array) .'"> 最后页</a>|';
                    }
                    else if($curr_page < $pages){
                        $multipage .= '<a href="'. pageurl($urlrule, 1, $array) .'">首页</a>|';
                        $multipage .= '<a href="'. pageurl($urlrule, $curr_page-1, $array;
                        $multipage .= '<a href="'. pageurl($urlrule, $curr_page+1, $array;
                        $multipage .= '<a href="'. pageurl($urlrule, $pages, $array) .'"> 最后页</a>|';
                    }
                    else if($curr_page == $pages){
                        $multipage .= '<a href="'. pageurl($urlrule, 1, $array) .'">首页</a>|';
                        $multipage .= '<a href="'. pageurl($urlrule, $curr_page-1, $array;
                    }
                }

//
    }
    return $multipage;
}

首页时

中间页

最后一页

写完这个之后再
lib/classes/template_cache.class.php中找到
$str .= '$pages = pages($'.$op.'_total, $page, $pagesize, $urlrule);';
下面加一行
$str .= '$test_pages = test_pages($'.$op.'_total, $page, $pagesize, $urlrule);';

然后前台调用时候原来写的是{$pages}  现在写{$test_pages}就可以了

网上的教程中有一部分我没用到也好用了这里注释一下,以备

当然如果使用过程中,发现SQL分页的不能正常使用,再在
$str .= ‘$r =$get_db->sql_query(“‘.$sql.’”);$s =$get_db->fetch_next();$pages=pages($s[\'count\'],$page, $pagesize, $urlrule);’;
添加这段代码:

$str .= '$r =$get_db->sql_query("'.$sql.'");$s =$get_db->fetch_next();$pages_my=pages_my($s[\'count\'],$page, $pagesize, $urlrule);';

 

网友评论
<