phpcmsV9 自定义分页函数与调用 - 不影响后台SQL分页

phpcmsV9 自定义分页函数与调用 - 不影响后台SQL分页


一、前言:

这里主要有二处需要修改:

  • 文件1. www\phpcms\libs\functions\global.func.php
  • 文件2. www\phpcms\libs\classes\template_cache.class.php

二、 响应式页面,样式效果预览:

宽屏幕尺寸

小屏幕尺寸


三、代码修改如下:

文件1. 自定义添加代码:
  • 复制function pages( )函数,并列粘贴在其后面,并命名为function wz_page()
  • 再更改 分页标签class类样式、等等代码。

重新复制粘贴,新命名的好处是:这样可随意调用,不用担心后台 SQL分页被影响!

在这里插入图片描述

代码如下:

/**
 * 分页函数 - wz_pages()
 *
 * @param $num 信息总数
 * @param $curr_page 当前分页
 * @param $perpage 每页显示数
 * @param $urlrule URL规则
 * @param $array 需要传递的数组,用于增加额外的方法
 * @return 分页
 */
function wz_pages($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="Total record">&nbsp;<b>'.$num.L('page_item').'</b></a>';
		if($curr_page>0) {
			$multipage .= ' <a href="'.pageurl($urlrule, $curr_page-1, $array).'" class="a1">'.L('previous').'</a>';
			if($curr_page==1) {
				$multipage .= ' <b>1</b>';
			} 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 .= ' <b>'.$i.'</b>';
			}
		}
		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').'</a>';
			} else {
				$multipage .= ' <a href="'.pageurl($urlrule, $pages, $array).'">'.$pages.'</a> <a href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'</a>';
			}
		} elseif($curr_page==$pages) {
			$multipage .= ' <b>'.$pages.'</b> <a href="'.pageurl($urlrule, $curr_page, $array).'" class="a1">'.L('next').'</a>';
		} else {
			$multipage .= ' <a href="'.pageurl($urlrule, $pages, $array).'">'.$pages.'</a> <a href="'.pageurl($urlrule, $curr_page+1, $array).'" class="a1">'.L('next').'</a>';
		}
	}
	return $multipage;
}

文件2. 自定义添加代码:
  • 【在第209行后面】
    即: $str .= '$pages = pages($'.$op.'_total, $page, $pagesize, $urlrule);'; 后面,
    新增代码片段1:
    $str .= '$wz_pages = wz_pages($'.$op.'_total, $page, $pagesize, $urlrule);';
  • 【在第181行后面】
    即: $str .= '$r = $get_db->sql_query("'.$sql.'");$s = $get_db->fetch_next();$pages=pages($s[\'count\'], $page, $pagesize, $urlrule);'; 后面,
    新增代码片段2:
    $str .= '$r = $get_db->sql_query("'.$sql.'");$s = $get_db->fetch_next();$wz_pages=wz_pages($s[\'count\'], $page, $pagesize, $urlrule);';

**注意行号:**版本不同行号也有可能不同,但只要找准对应位置即可。

在这里插入图片描述

在这里插入图片描述


经过上述修改,就可以实现分页代码的自定义样式修改,下面进入调用方法。


四、调用代码:

<div class="share">
{pc:content action="lists" catid="$catid" num="8" order="listorder DESC" page="$page"}
	<ul>
		{loop $data $r}
		{php $db = pc_base::load_model('hits_model'); $_r = $db->get_one(array('hitsid'=>'c-'.$modelid.'-'.$r[id])); $views = $_r[views]; } 
		<li> <div class="shareli"><a href="{$r[url]}" target="_blank"> <i><img src="{$r[thumb]}"></i>
	      <h2><b>{$r[title]}</b></h2>
	      <!--<p>发表时间{date('Y-m-d H:i:s',$r[inputtime])}</p>-->
	      <span>点击量 | {$views}</span> </a></div> 
	      <!--<span>喜欢 | 190</span> </a></div> -->
		</li>
		{/loop}
	</ul>
	
{/pc}
</div>
<!--分页组件-->
<!--<div id="pages" class="text-c pagelist">{$pages}</div>-->
<div class="pagelist">{$wz_pages}</div>

五、项目页面截图示下:

在这里插入图片描述


以上就是关于“ phpcmsV9 自定义分页函数与调用 - 不影响后台SQL分页 ” 的全部内容。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值