您现在的位置是:首页 > 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函数对分页是否能传递相关参数很重要!)第三步:前台模板调用//选项调用
{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>

本文标签:

很赞哦! ()

相关源码

  • (自适应)高端集团跨国公司产业联盟机构网站模板免费下载基于PbootCMS内核开发的集团级企业网站模板,采用响应式设计架构,确保在各类移动设备上获得浏览体验。通过模块化布局与简约大气的视觉风格,帮助集团企业高效展示组织架构、发展历程和业务矩阵,建立专业的企业形象窗口。查看源码
  • (自适应)绿色园林建筑花卉园艺艺术模板免费下载为景观设计及园艺企业打造的响应式网站框架,基于PbootCMS系统开发,帮助传统园林行业建立现代化数字展示平台。采用标准DIV+CSS前端架构,代码精简无冗余。查看源码
  • (PC+WAP)红色户外岗亭钢结构岗亭pbootcms网站模板为钢结构岗亭、户外设施企业打造的高端响应式营销门户,基于PbootCMS开源内核深度开发,采用HTML5自适应架构,实现PC与移动端数据实时同步展示。查看源码
  • (PC+WAP)化工材料企业环保能源绿色营销型pbootcms模板源码下载本模板为化工材料及环保能源企业设计,采用PbootCMS开发,可展示各类化工产品、环保技术及能源解决方案。查看源码
  • (自适应响应式)蓝色环保机械设备网站pbootcms模板HTML5源码下载基于PbootCMS的生态环境技术展示平台,通过内容调整可应用于新能源设备、污水处理、空气净化等环保相关领域。设备参数采用对比表格展示,技术原理支持图文混排;查看源码
  • (响应式)WordPress主题Ripro9.0博客免扩展二开版RiPro9.0是基于RiPro8.9版本深度二开优化的资源付费主题,源码修正,修复原版多处功能异常,确保系统稳定运行。支持虚拟主机环境部署,无需特殊服务器配置。查看源码
分享笔记 (共有 篇笔记)
验证码:

本栏推荐