PHPCMS 栏目页及列表页分页修改

所属分类: CMS教程 / phpcms 阅读数: 656
收藏 0 赞 0 分享
网站栏目页及列表页要实现的效果如下:
1、栏目页最多只列出100页;
2、列表页不限制最大页数,有多少页就列出多少页。
要实现这个效果,需要改动的文件有3个,文件及改动内容如下:

复制代码
代码如下:

/*
文件:/include/global.func.php
函数:get
*/
/*
为 get 函数添加一个参数
ismaxpage 就是所添加的参数,用于判断是否启用“列表页最大页数”这个参数
而插入代码的部分是为了改变total的值,即记录集总数
*/
function get($sql, $rows = 0, $page = 0, $dbname = '', $dbsource = '', $urlrule = '', $distinct_field = '', $catid = 0, $ismaxpage = 0) {
...
if($dbname || $dbsource)
{
$r = $db->get_one("SELECT COUNT(*) AS `count` ".stristr($sql, 'from'));
$total = $r['count'];
}
elseif($distinct_field)
{
$total = cache_count("SELECT COUNT(distinct $distinct_field) AS `count` ".stristr($sql, 'from'));
}
else
{
$total = cache_count("SELECT COUNT(*) AS `count` ".stristr($sql, 'from'));
}
/* 插入以下代码 开始 */
global $PHPCMS;
if ($ismaxpage) {
$total = min($total, $PHPCMS['maxpage']*$rows);
}
/* 插入以上代码 结束 */
$pages = pages($total, $page, $rows, $urlrule, '', $catid);
...
}


复制代码
代码如下:

/*
文件:/include/template.func.php
函数:get_parse
*/
/*
前台 get 标签最后是转换成 get 函数,以下是处理 get 标签的函数
因为 get 函数增加了一个参数 $ismaxpage,所以这里也需要做相应修改
以下是修改后的部分代码
*/
function get_parse($str)
{
...
extract($r);
if(!isset($dbsource)) $dbsource = '';
if(!isset($dbname)) $dbname = '';
if(!isset($sql)) $sql = '';
if(!isset($rows)) $rows = 0;
if(!isset($urlrule)) $urlrule = '';
if(!isset($catid)) $catid = 0;
if(!isset($distinctfield)) $distinctfield = '';
if(!isset($return) || !preg_match("/^\w+$/i", $return)) $return = 'r';
if(!isset($ismaxpage)) $ismaxpage = 0; /* 增加部分 */
if(isset($page))
{
/* 修改部分,增加了 $ismaxpage 这个参数,仔细看 */
$str = "<?php \$ARRAY = get(\"$sql\", $rows, $page, \"$dbname\", \"$dbsource\", \"$urlrule\",\"$distinctfield\",\"$catid\", $ismaxpage);\$DATA=\$ARRAY['data'];\$total=\$ARRAY['total'];\$count=\$ARRAY['count'];\$pages=\$ARRAY['pages'];unset(\$ARRAY);foreach(\$DATA AS \$n=>\${$return}){\$n++;?>";
}
...
}


复制代码
代码如下:

/*
文件:/admin/html.inc.php
*/
/* 找到以下代码 */
if($CATEGORY[$catid]['child'])
{
$pages = 1;
$html->category($catid);
}
else
{
$offset = $pagesize*($page-1);
if($page == 1)
{
$contents = cache_count("SELECT COUNT(*) AS `count` FROM `".DB_PRE."content` WHERE catid=$catid AND status=99");
$total = ceil($contents/$PHPCMS['pagesize']);
$pages = ceil($total/$pagesize);
}
$max = min($offset+$pagesize, $total);
for($i=$offset; $i<=$max; $i++)
{
$html->category($catid, $i);
}
}
/* 然后把上面的代码替换成以下的代码 */
$offset = $pagesize*($page-1);
if($page == 1)
{
$condition=get_sql_catid($catid);
$contents = cache_count("SELECT COUNT(*) AS `count` FROM `".DB_PRE."content` WHERE status=99 $condition");
$total = ceil($contents/$PHPCMS['pagesize'])+1;
/* 以下这行代码确保了生成的栏目及列表页的数量是正确的,该生成多少页就是多少页 */
$total = $CATEGORY[$catid]['child'] ? min($total, $PHPCMS['maxpage']+1) : $total;
$pages = ceil($total/$pagesize);
}
$max = min($offset+$pagesize, $total);
for($i=$offset; $i<$max; $i++)
{
$html->category($catid, $i);
}

以下是一个栏目页及列表页模板的示例


复制代码
代码如下:

<?php
$catids = str_replace('`catid`', 'a.`catid`', get_sql_catid($catid));
$sql = "
SELECT a.contentid, a.catid, a.title, a.keywords, a.thumb, a.userid, a.updatetime, a.inputtime, a.islink, a.url, a.style
FROM `phpcms_content` a
WHERE a.status=99 $catids ORDER BY a.contentid DESC";
/* 判断是否有子栏目,有的话就开启“列表页最大页数”这个参数,限制栏目页页数 */
if ($child) {
$ismaxpage = 1;
$page = min($page, $PHPCMS['maxpage']); /* 为了防止在地址栏输入页数,这里是要滴 */
}
?>
<ul>
{get sql="$sql" rows="20" page="$page" catid="$catid" ismaxpage="$ismaxpage"}
<li>{$r[title]}</li>
{/get}
</ul>
<div>{$pages}</div>

经过以上这么一翻捣鼓,一开始的那效果就出来了。基本思路就是先要为get标签增加一个参数,用于判断是否开启“列表页最大页数”,然后生成静态页面的时候限制一下栏目页,不然它有多少生成多少。
PHPCMS 确实挺好,但需要改进的地方同样也很多,很多细节都没处理好,而有些功能都不是给人用的。希望 PHPCMS 能越来越强大!
更多精彩内容其他人还在看

PHPCMS系统自带标签说明

关键字描述:说明 标签 系统 channelid 首页 专题 推荐 图片 文章 PHPCMS系统自带标签说明 首页最新文章列表 articlelist(0,1,0,1,0,0,10,46,0,0,0,1,2,0,0,0,1,1) 首页热点下载列表 downlist
收藏 0 赞 0 分享

phpcms语法规则

关键字描述:规则 语法   < if > loop name 字母 --> /loop 1、变量表示 {$name}被解析成<?=$name?>,表示显示变量$name的值,其中的“name&rdquo
收藏 0 赞 0 分享

phpcms将下载地址替换为图片显示

关键字描述:图片 显示 地址 下载
收藏 0 赞 0 分享

如何把PHPCMS的网站和数据库删除

关键字描述:删除 数据库 网站 如何 PHPCMS mysql 程序 修改 如果 如何把PHPCMS的网站和数据库删除 如果网站换空间了,原来的空间还保存着PHPCMS的mysql数据库,那我们怎么把他删除呢? 很简单 1.删除mysql数据库:通过PHPMYADMIN
收藏 0 赞 0 分享

phpcms关于标签和频道的基础概念

关键字描述:基础 概念 频道 标签 关于   调用 一个 文章 我们 phpcms一直是很多站长使用的建站系统,我们今天谈一下phpcms标签和频道的一些基础知识。 1、 何谓标签? phpcms 一直以来采用的是标签调用的方法,这样就能
收藏 0 赞 0 分享

PHPCMS网站转移空间教程

关键字描述:教程 空间 转移 网站 文件 目录 数据库   PHPCMS 有关phpcms网站转移空间,备份数据库转移空间的文章不是很多,所以就发表操作方法: 1.备份mysql数据库 现在的空间基本都有phpmyadmin 首先进入phpmyadm
收藏 0 赞 0 分享

phpcms常见问题解答

关键字描述:常见 频道 目录 建立 设置 ftp 标签   文章 可以 1.为什么phpcms首页幻灯片怎么显示不出来? 答:需要设置文章的 标题图片 如果设置标题图片,则可以在首页以及栏目页以图片方式链接到文章。 2.自定义phpcms的标签
收藏 0 赞 0 分享

phpcms如何使用水印功能

关键字描述:功能 使用 如何 水印 图片 字体 文字 需要 文件 中文 phpcms水印功能只有在添加标题图片的时候生成带水印的图片。 编辑器上传的图片不能增加水印和缩略图 添加水印功能: 1,首先查看服务器参数查看 图形处理 GD Library 这个选项是不
收藏 0 赞 0 分享

PHPCMS 模板安装导入教程

关键字描述:教程 导入 安装 模板 目录 更新 管理 依次 然后 方案 关于phpcms模板安装教程,导入模板的方法: 1.模板安装 下载已发布共享的模板文件包,解压后上传模板目录至templates目录下,进入后台模板风格 -〉方案管理(见下图),启
收藏 0 赞 0 分享

phpcms模仿QQ和MSN消息提示的效果

关键字描述:提示 效果 消息 模仿 " popTop if else & screen.width-2 你一定很喜欢像QQ或者MSN好友登录提示的效果吧,那么怎么样能在网页中实现呢?正好我在蓝色理想中发现了这段代码,贴出给大家看看(注意,如果使用以下代码,先
收藏 0 赞 0 分享
查看更多