您现在的位置是:首页 > cms教程 > phpcms教程phpcms教程
phpcms联动筛选修改方法
王颢锵2025-05-23phpcms教程已有人查阅
导读联动筛选的问题其实这些函数,都是从phpcms的分类信息模块的函数复制过来的。所有的分类信息函数如下:下载地址。当然,这个是最老的分类信息模块了
联动筛选的问题其实这些函数,都是从phpcms的分类信息模块的函数复制过来的。所有的分类信息函数如下:
下载地址。当然,这个是最老的分类信息模块了,较新版的已经找不到了,但是很多人,都在使用这里的函数,来做筛选。复制内容如下
phpcms v9实现数据内容筛选功能,很多人都想要这个功能,今天我就讲一下我是怎么实现phpcms v9数据内容筛选功能的
注意:此教程目前只适用于动态页面,并且可能有些不完善的地方,因为数据是直接读取SQL的,所以会把同模型的其他栏目数据调用出来。所以建议单独新建一个模型。第一步: 添加字段:
后台 --> 内容 --> 内容相关设置 --> 模型管理 --> 文章模型 --> 字段管理 --> 添加字段如下示例
第二步:添加自定义函数:(他这个函数代码,是错了,但是我还是粘贴出来了)
建议下载 这个包。有具体的函数,以及使用方法。点击下载
将以下代码添加到 phpcms/libs/functions/extention.func.php 文件复制了代码以后,网站就500了,应该是代码内部的语法出了问题。
这是因为,我可能以前在某处,加载过这个文件,重复的加载了这些函数,所以会报500错误,再说一次,千万不要搞phpcms,这些报错,真的很恶心,你要排查半天。最终发现,我在auoload文件里,加载了 phpcms的 分类信息函数,那些函数,跟新增的函数重名了。
(注:makeurlrule函数对分页是否能传递相关参数很重要!)第三步:前台模板调用//选项调用
之前的一篇文章:解决lists标签中,加上where后其他条件失效的问题,其他条件失效了,如catid,thumb等等,也就是无法获取当前栏目的信息,而是把整个栏目下的所有文章都调用出来了!
打开/phpcms/modules/content/classes/目录下的content_tag.class.php这个文件,把下面的代码(大概第63行)
通过研究缓存得知,调用分页总数的函数是:
大功告成,这样既然正常分页传参,也能正常获取当前栏目信息,获取的信息总数也正确了,他是这样说,具体对不对,我不知道!测试一下吧。问题1.文章说,必须修改原来的url为动态url模式才行。我的解决办法
首先,网站已经使用了自定义的url规则,下图标红的是我使用的。
确实,在生成选项的时候,是会出现访问权限不存在的问题,因为url中没有传入catid参数。
我的解决办法是
下载地址。当然,这个是最老的分类信息模块了,较新版的已经找不到了,但是很多人,都在使用这里的函数,来做筛选。复制内容如下
phpcms v9实现数据内容筛选功能,很多人都想要这个功能,今天我就讲一下我是怎么实现phpcms v9数据内容筛选功能的
注意:此教程目前只适用于动态页面,并且可能有些不完善的地方,因为数据是直接读取SQL的,所以会把同模型的其他栏目数据调用出来。所以建议单独新建一个模型。第一步: 添加字段:
后台 --> 内容 --> 内容相关设置 --> 模型管理 --> 文章模型 --> 字段管理 --> 添加字段如下示例
第二步:添加自定义函数:(他这个函数代码,是错了,但是我还是粘贴出来了)
建议下载 这个包。有具体的函数,以及使用方法。点击下载
将以下代码添加到 phpcms/libs/functions/extention.func.php 文件复制了代码以后,网站就500了,应该是代码内部的语法出了问题。
这是因为,我可能以前在某处,加载过这个文件,重复的加载了这些函数,所以会报500错误,再说一次,千万不要搞phpcms,这些报错,真的很恶心,你要排查半天。最终发现,我在auoload文件里,加载了 phpcms的 分类信息函数,那些函数,跟新增的函数重名了。
(注:makeurlrule函数对分页是否能传递相关参数很重要!)第三步:前台模板调用//选项调用
{loop filters('chengshi',1) $r}
{$r[menu]}
{/loop}
//信息调用
{php $sql = structure_filters_sql($modelid);}
{php $urlrule = makeurlrule()}
{pc:content action="lists" catid="$catid" where="$sql" modelid="$modelid" num="10" page="$page" moreinfo="1" urlrule="$urlrule" return="data" }
{loop $data $r}
........
{/loop}
{/pc}
第四步:修复list条件下加入where后其他条件失效的问题.这是其中一种解决办法,我使用了另一种办法,解决了之前的一篇文章:解决lists标签中,加上where后其他条件失效的问题,其他条件失效了,如catid,thumb等等,也就是无法获取当前栏目的信息,而是把整个栏目下的所有文章都调用出来了!
打开/phpcms/modules/content/classes/目录下的content_tag.class.php这个文件,把下面的代码(大概第63行)
if(isset($data['where'])) {
$sql = $data['where'];
} else {
$thumb = intval($data['thumb']) ? " AND thumb != ''" : '';
if($this->category[$catid]['child']) {
$catids_str = $this->category[$catid]['arrchildid'];
$pos = strpos($catids_str,',')+1;
$catids_str = substr($catids_str, $pos);
$sql = "status=99 AND catid IN ($catids_str)".$thumb;
} else {
$sql = "status=99 AND catid='$catid'".$thumb;
}
}
替换为
if(isset($data['where'])) {
$where = (isset($data['where'])&&(!empty($data['where'])))?' AND '.$data['where']:'';
$thumb = intval($data['thumb']) ? " AND thumb != ''" : '';
if($this->category[$catid]['child']) {
$catids_str = $this->category[$catid]['arrchildid'];
$pos = strpos($catids_str,',')+1;
$catids_str = substr($catids_str, $pos);
$sql = "status=99".$where." AND catid IN ($catids_str)".$thumb;
} else {
$sql = "status=99".$where." AND catid='$catid'".$thumb;
}
} else {
$thumb = intval($data['thumb']) ? " AND thumb != ''" : '';
if($this->category[$catid]['child']) {
$catids_str = $this->category[$catid]['arrchildid'];
$pos = strpos($catids_str,',')+1;
$catids_str = substr($catids_str, $pos);
$sql = "status=99 AND catid IN ($catids_str)".$thumb;
} else {
$sql = "status=99 AND catid='$catid'".$thumb;
}
}
第五步:解决分页数量不对的问题通过研究缓存得知,调用分页总数的函数是:
$content_total = $content_tag->count(array('catid'=>$catid,'where'=>$sql,'modelid'=>$modelid,'moreinfo'=>'1','limit'=>$offset.",".$pagesize,'action'=>'lists',));
通过这个,找到phpcms\modules\content\classes\content_tag.class.php大致36-56行,count函数如下:
public function count($data) {
if($data['action'] == 'lists') {
$catid = intval($data['catid']);
if(!$this->set_modelid($catid)) return false;
if(isset($data['where'])) {
$sql = $data['where'];
} else {
if($this->category[$catid]['child']) {
$catids_str = $this->category[$catid]['arrchildid'];
$pos = strpos($catids_str,',')+1;
$catids_str = substr($catids_str, $pos);
$sql = "status=99 AND catid IN ($catids_str)";
} else {
$sql = "status=99 AND catid='$catid'";
}
}
return $this->db->count($sql);
}
}
改为
public function count($data) {
if($data['action'] == 'lists') {
$catid = intval($data['catid']);
$catids_str = $this->category[$catid]['arrchildid'];
if(!$this->set_modelid($catid)) return false;
if(isset($data['where'])) {
$sql = $data['where'];
if($this->category[$catid]['child']) {
$catids_str = $this->category[$catid]['arrchildid'];
$pos = strpos($catids_str,',')+1;
$catids_str = substr($catids_str, $pos);
$sql = $sql." AND catid IN ($catids_str)";
} else {
$sql = $sql." AND catid='$catid'";
}
} else {
if($this->category[$catid]['child']) {
$catids_str = $this->category[$catid]['arrchildid'];
$pos = strpos($catids_str,',')+1;
$catids_str = substr($catids_str, $pos);
$sql = "status=99 AND catid IN ($catids_str)";
} else {
$sql = "status=99 AND catid='$catid'";
}
}
return $this->db->count($sql);
}
}
你会发现,分页统计的修改原理仍然是$where条件下,没有传入当前栏目id这个参数!大功告成,这样既然正常分页传参,也能正常获取当前栏目信息,获取的信息总数也正确了,他是这样说,具体对不对,我不知道!测试一下吧。问题1.文章说,必须修改原来的url为动态url模式才行。我的解决办法
首先,网站已经使用了自定义的url规则,下图标红的是我使用的。
确实,在生成选项的时候,是会出现访问权限不存在的问题,因为url中没有传入catid参数。
我的解决办法是
<!--获取当前请求的url,检测是否存在catid的值,后续,判断,如果存在,就直接返回筛选的url,如果不存在,就添加上-->
{php $urlstr=$_SERVER['REQUEST_URI']}
{php $flag=preg_match('/catid=\d*/',$urlstr)}
<div class="info_tit">
<h2>{$catname}</h2>
<div class="xifen">
<!--根据url是否存在catid进行操作-->
{if $flag==true}
{loop filters('chengshi',1) $r}
{$r[menu]}
{/loop}
{else}
{loop filters('chengshi',1) $r}
{php $jiaru="catid="}
{php $jiaru=$jiaru.$catid}
{str_replace('catid=',$jiaru,$r[menu])}
{/loop}
{/if}
</div>
</div>
本文标签:
很赞哦! ()
图文教程
phpcms页面乱码的解决方法
phpcms页面乱码怎么办?phpcms静态页面乱码问题用phpcms做网站,安装时设置的编码方式是UTF-8,数据库编码方式也是UTF-8。页面上的编码方式也是UTF-8。
phpcms替换首页的方法示例
首先做一个静态的企业站主页:将网页中的JS以及CSS全部导为 JS和CSS文件放入statics文件夹下的相应位置。并将文件地址根据以下格式修改:
phpcmsV9数据模型基类介绍
在学习《phpcms V9首页模板文件解析》的第七步,我们看到content_model类,文件路径:phpcms/model/content_model.class.php从代码中
phpcmsv9添加文章出错的原因和解决方法
phpcms v9添加文章出错怎么办?PHPCMS添加文章失败原因在添加某一篇文章时,添加时间非常久,而且最终结果是失败了。整站都打不开了,只能重启
相关源码
-
响应式粉色美容整形化妆品pbootcms网站模板开源源码该网站模板为美容整形、化妆品企业设计,采用响应式布局确保在手机、平板及PC端自动适配显示效果。基于PbootCMS内核开发,支持一键替换图文内容快速转换至其他行业应用。查看源码 -
(自适应)响应式文章博客互联网新闻pbootcms模板下载本模板基于PbootCMS开发,专为科技新闻、互联网资讯和文章博客类网站设计。采用响应式布局技术,确保在电脑、平板和手机上都能获得最佳浏览体验。适用于科技媒体、行业博客查看源码 -
(自适应响应式)陶瓷研磨盘抛光机械设备pbootcms网站模板本模板基于PbootCMS系统开发,为研磨抛光设备制造企业设计,特别适合陶瓷研磨盘、抛光设备等表面处理设备展示。采用响应式布局技术,确保各类设备的参数和工艺在不同终端上都能清晰呈现。查看源码 -
(自适应)营销型健身器材产品设备类pbootcms模板网站为健身器材企业打造的营销型网站模板,基于PbootCMS开源内核开发。采用HTML5响应式架构,PC与移动端数据实时同步,适配多终端展示场景。查看源码 -
(自适应)帝国cms7.5文章新闻博客整站源码( 带会员中心)本模板基于帝国CMS内核开发,为新闻资讯、个人博客及作品展示类网站设计。采用响应式布局技术,确保在手机、平板和电脑等不同设备上都能获得良好的浏览体验。查看源码 -
(PC+WAP)化工材料企业环保能源绿色营销型pbootcms模板源码下载本模板为化工材料及环保能源企业设计,采用PbootCMS开发,可展示各类化工产品、环保技术及能源解决方案。查看源码
| 分享笔记 (共有 篇笔记) |
