服务器之家:专注于服务器技术及软件下载分享
分类导航

DEDECMS|帝国CMS|Discuz|PHPCMS|Wordpress|ZBLOG|ECSHOP|苹果CMS|极致CMS|CMS系统|

服务器之家 - 建站程序 - PHPCMS - Phpcms V9列表分页自定义页码文字(改成中文)

Phpcms V9列表分页自定义页码文字(改成中文)

2019-10-12 12:39PHPCMS教程网 PHPCMS

一般列表分页的页码显示是英文的,而中文站希望页面和分页列表希望是中文的,另外有时候还需要自定义,这就涉及到Phpcms V9列表分页自定义页码文字,有此需求的朋友可以参考下本文

在使用PC v9建站过程中,如果是外贸站,一般列表分页的页码显示是英文的,而中文站希望页面和分页列表希望是中文的,另外有时候还需要自定义,这就涉及到Phpcms V9列表分页自定义页码文字的方法 

在用PHPCMS V9的过程中,可能一般人都不会在意分页功能,因为调用他实在是很简单,需要修改的估计也就是分页功能的样式了,拿系统自带的模板来看 

复制代码

代码如下:


<div id="pages" class="text-c">{$pages}</div> 


我们可以修改class来自定义样式,当然有人会说,这个只能修改DIV的样式,无法修改里面的内容的样式,其实之需要看一下这段代码解析出来的实际代码就知道了,而这里的样式可以直接通过head部分内读取的CSS来代替,我就可以在CSS里面添加这样一段,为了方便测试,我直接写在head标签内: 

复制代码

代码如下:


.text-c {margin:10px 0;} 
.text-c a {padding:5px;margin:0 8px;border:1px solid #ccc;background-color:#eee;} 


经过测试是有效的.这里不在说这个了,重点是{$pages}输出的分页效果是固定的,如何让他能够满足自己的需求,比如最简单的系统默认是显示多少条,用上一页,下一页来表示,如果我想改成向后翻,向前翻,怎么办?我经过查找相关资料,对这个功能进行整理得出结果与大家分享出来,涉及修改到的文件只有下面两个: 

复制代码

代码如下:


\phpcms\languages\zh-cn\system.lang.php 
\phpcms\libs\functions\global.func.php 
\ phpcms\lib\classes\template_cache.class.php 


具体怎么弄,待我慢慢与大家讲解: 

首先打开system.lang.php,找到29行LANG['next'] = ‘下一页’;处,你可以在下面插入自定义的内容,比如向后翻,向前翻,整理效果应该是这样的,添加完后保存可以关闭了。 

...... 
$LANG['page_item'] = '条'; 
$LANG['previous'] = '上一页'; 
$LANG['next'] = '下一页'; 
$LANG['page_item_my'] = '篇'; //自定义 
$LANG['previous_my'] = '向前翻'; //自定义 
$LANG['next_my'] = '向后翻'; //自定义 
...... 

然后打开global.func.php,搜索分页函数找到找到function pages…,在这个函数后复制原函数并修改添加自己想要定义的函数,例如: 

复制代码

代码如下:


//自定义分页函数 
function pages_my($num, $curr_page, $perpage = 20, $urlrule = '', $array = array(),$setpages = 10) { 
if(defined('URLRULE') && $urlrule == '') { 
$urlrule = URLRULE; 
$array = $GLOBALS['URL_ARRAY']; 
} elseif($urlrule == '') { 
$urlrule = url_par('page={$page}'); 

$multipage = ''; 
if($num > $perpage) { 
$page = $setpages+1; 
$offset = ceil($setpages/2-1); 
$pages = ceil($num / $perpage); 
if (defined('IN_ADMIN') && !defined('PAGES')) define('PAGES', $pages); 
$from = $curr_page - $offset; 
$to = $curr_page + $offset; 
$more = 0; 
if($page >= $pages) { 
$from = 2; 
$to = $pages-1; 
} else { 
if($from <= 1) { 
$to = $page-1; 
$from = 2; 
} elseif($to >= $pages) { 
$from = $pages-($page-2); 
$to = $pages-1; 

$more = 1; 

$multipage .= '<a class="a1">'.$num.L('page_item_my').'</a>'; 
if($curr_page>0) { 
$multipage .= ' <a href="'.pageurl($urlrule, $curr_page-1, $array).'" class="a1">'.L('previous_my').'</a>'; 
if($curr_page==1) { 
$multipage .= ' <span>1</span>'; 
} elseif($curr_page>6 && $more) { 
$multipage .= ' <a href="'.pageurl($urlrule, 1, $array).'">1</a>..'; 
} else { 
$multipage .= ' <a href="'.pageurl($urlrule, 1, $array).'">1</a>'; 


for($i = $from; $i <= $to; $i++) { 
if($i != $curr_page) { 
$multipage .= ' <a href="'.pageurl($urlrule, $i, $array).'">'.$i.'</a>'; 
} else { 
$multipage .= ' <span>'.$i.'</span>'; 


if($curr_page<$pages) { 
if($curr_page<$pages-5 && $more) { 
$multipage .= ' ..<a href="'.pageurl($urlrule, $pages, $array).'">'.$pages.'</a> <a href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next_my').'</a>'; 
} else { 
$multipage .= ' <a href="'.pageurl($urlrule, $pages, $array).'">'.$pages.'</a> <a href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next_my').'</a>'; 

} elseif($curr_page==$pages) { 
$multipage .= ' <span>'.$pages.'</span> <a href="'.pageurl($urlrule, $curr_page, $array).'" class="a1">'.L('next_my').'</a>'; 
} else { 
$multipage .= ' <a href="'.pageurl($urlrule, $pages, $array).'">'.$pages.'</a> <a href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next_my').'</a>'; 


return $multipage; 


最后打开template_cache.class.php,找到 

复制代码

代码如下:


$str .= ‘$pages = pages($’.$op.’_total, $page, $pagesize, $urlrule);’; 


处,在下面添加: 

复制代码

代码如下:


$str .= '$pages_my= pages_my($'.$op.'_total, $page, $pagesize, $urlrule);'; 


当然如果使用过程中,发现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);'; 


至此大功告成,接下来,你只用在你想要的模板的分页出使用就可以了,例如开头的格式 

复制代码

代码如下:


<div id="pages" class="myListPage">{$pages_my}</div> 


并写上对应的CSS就可以了。

延伸 · 阅读

精彩推荐