十年網(wǎng)站開發(fā)經(jīng)驗 + 多家企業(yè)客戶 + 靠譜的建站團隊
量身定制 + 運營維護+專業(yè)推廣+無憂售后,網(wǎng)站問題一站解決
下面為大家分享一個PHPCMS V9二次開發(fā)自定義分頁函數(shù)的方法。
方法如下:
首先打開 phpcms\libs\functions\global.func.php這個文件,找到分頁函數(shù),復(fù)制一下,粘貼到默認分頁函數(shù)的下面,重新命名,比如我的就命名為wz_pages,保存。
打開 phpcms/libs/classes/template_cache.class.php,找到207行的:

$str .= '$pages = pages($'.$op.'_total, $page, $pagesize, $urlrule);';
在這行的下面加上:
$str .= '$wz_pages = wz_pages($'.$op.'_total, $page, $pagesize, $urlrule);';
保存。最后,如果你要使用你自定義的分頁函數(shù),那么在模板中直接用{$wz_pages}就可以了,以后要修改樣式,直接修改:
phpcms\libs\functions\global.func.php這個文件中的wz_pages函數(shù)就可以了,不會影響到后臺。
后續(xù)優(yōu)化:
使用過程中,發(fā)現(xiàn)使用SQL分頁的不能正常使用,得再添加如下代碼:
打開 phpcms/libs/classes/template_cache.class.php,找到178行的:
$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();$wz_pages=wz_pages($s[\'count\'], $page, $pagesize, $urlrule);';
這樣,SQL的分頁也正常了。
再次后續(xù)優(yōu)化:
有朋友提到,會員中心的收藏列表分頁不能使用上面的辦法。
因為收藏列表的分頁函數(shù)直接在其他文件定好了,所以通過修改模板緩存文件是不可行的,下面提供修改辦法:
具體修改見下面:
phpcms\libs\classes\model.class.php 第61行
$this->pages = pages($this->number, $page, $pagesize, $urlrule, $array, $setpages);
把上面這行修改成:
$this->pages = wz_pages($this->number, $page, $pagesize, $urlrule, $array, $setpages);
(模板中的{$pages}不用改為{$wz_pages})
上面是第一種辦法。
不過這樣子的話,可能后臺也會影響到了,這個地方好像是控制好多地方的, 也可以這樣修改,還是上面那個文件,61行不要修改。直接在61行下面添加:
$this->wz_pages= wz_pages($this->number, $page, $pagesize, $urlrule, $array, $setpages);
再去到:phpcms\modules\member\index.php 718行,把下面這行
$pages = $this->favorite_db->pages;
修改為:
$wz_pages = $this->favorite_db->wz_pages;
模板中的{$pages}要修改為{$wz_pages},這是以收藏列表為例子,其他的也大同小異了。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)cdcxhl.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。