如下图所示功能:

首先,用下面这些代码替换掉phpcms/libs/functions/extention.func.php的内容

<?php
/***  extention.func.php 用户自定义函数库** @copyright            (C) 2005-2010 PHPCMS* @license                http://www.phpcms.cn/license/* @lastmodify            2010-10-27*//*** 通过指定keyid形式显示所有联动菜单* @param  $keyid 菜单主id* @param  $linkageid  联动菜单id,0调用顶级* @param  $modelid 模型id* @param  $fieldname  字段名称*/
function show_linkage($keyid, $linkageid = 0, $modelid = '', $fieldname='zone') {$datas = $infos = $array = array();$keyid = intval($keyid);$linkageid = intval($linkageid);//当前菜单id$field_value = intval($_GET[$fieldname]);$urlrule = structure_filters_url($fieldname,$array,1,$modelid);if($keyid == 0) return false;$datas = getcache($keyid,'linkage');$infos = $datas['data'];foreach($infos as $k=>$v){if($v['parentid']==$field_value){$array[$k]['name'] = $v['name'];$array[$k]['value'] = $k;$array[$k]['url'] = str_replace('{'.$fieldname.'}',$k,$urlrule);$array[$k]['menu'] = $field_value == $k ? '<em>'.$v['name'].'</em>' : '<a href='.$array[$k]['url'].'>'.$v['name'].'</a>' ;}}return $array;}/*** 构造筛选URL*/
function structure_filters_url($fieldname,$array=array(),$type = 1,$modelid) {if(empty($array)) {$array = $_GET;} else {$array = array_merge($_GET,$array);}//TODO$fields = getcache('model_field_'.$modelid,'model');if(is_array($fields) && !empty($fields)) {ksort($fields);foreach ($fields as $_v=>$_k) {if($_k['filtertype'] || $_k['rangetype']) {if(strpos(URLRULE,'.html') === FALSE) $urlpars .= '&'.$_v.'={$'.$_v.'}';else $urlpars .= '-{$'.$_v.'}';}}}//后期增加伪静态等其他url规则管理,apache伪静态支持9个参数if(strpos(URLRULE,'.html') === FALSE) $urlrule =APP_PATH.'index.php?m=content&c=index&a=lists&catid={$catid}'.$urlpars.'&page={$page}' ;else $urlrule =APP_PATH.'list-{$catid}'.$urlpars.'-{$page}.html';//根据get传值构造URLif (is_array($array)) foreach ($array as $_k=>$_v) {if($_k=='page') $_v=1;if($type == 1) if($_k==$fieldname) continue;$_findme[] = '/{\$'.$_k.'}/';$_replaceme[] = $_v;}//type 模式的时候,构造排除该字段名称的正则if($type==1) $filter = '(?!'.$fieldname.'.)';$_findme[] = '/{\$'.$filter.'([a-z0-9_]+)}/';$_replaceme[] = '';$urlrule = preg_replace($_findme, $_replaceme, $urlrule);return         $urlrule;
}/*** 生成分类信息中的筛选菜单* @param $field   字段名称* @param $modelid  模型ID*/
function filters($field,$modelid,$diyarr = array()) {$fields = getcache('model_field_'.$modelid,'model');$options = empty($diyarr) ?  explode("\n",$fields[$field]['options']) : $diyarr;$field_value = intval($_GET[$field]);foreach($options as $_k) {$v = explode("|",$_k);$k = trim($v[1]);$option[$k]['name'] = $v[0];$option[$k]['value'] = $k;$option[$k]['url'] = structure_filters_url($field,array($field=>$k),2,$modelid);$option[$k]['menu'] = $field_value == $k ? '<em>'.$v[0].'</em>' : '<a href='.$option[$k]['url'].'>'.$v[0].'</a>' ;}$all['name'] = '全部';$all['url'] = structure_filters_url($field,array($field=>''),2,$modelid);$all['menu'] = $field_value == '' ? '<em>'.$all['name'].'</em>' : '<a href='.$all['url'].'>'.$all['name'].'</a>';array_unshift($option,$all);return $option;
}/*** 获取联动菜单层级* @param  $keyid     联动菜单分类id* @param  $linkageid 菜单id* @param  $leveltype 获取类型 parentid 获取父级id child 获取时候有子栏目 arrchildid 获取子栏目数组*/
function get_linkage_level($keyid,$linkageid,$leveltype = 'parentid') {$child_arr = $childs = array();$leveltypes = array('parentid','child','arrchildid','arrchildinfo');$datas = getcache($keyid,'linkage');$infos = $datas['data'];if (in_array($leveltype, $leveltypes)) {if($leveltype == 'arrchildinfo') {$child_arr = explode(',',$infos[$linkageid]['arrchildid']);foreach ($child_arr as $r) {$childs[] = $infos[$r];}return $childs;} else {return $infos[$linkageid][$leveltype];}}
}// 根据linkageid递归到父级
function get_parent_url($modelid,$field,$linkageid=0,$array = array()){$modelid = intval($modelid);if(!$modelid || empty($field)) return false;$fields = getcache('model_field_'.$modelid,'model');$keyid = $fields[$field]['linkageid'];$datas = getcache($keyid,'linkage');$infos = $datas['data'];if(empty($linkageid)){$linkageid = intval($_GET[$field]);if(!$linkageid) return false;}$urlrule = structure_filters_url($field,array(),1,$modelid);$urlrule = str_replace('{$'.$field.'}',$infos[$linkageid]['parentid'],$urlrule);array_unshift($array,array('name'=> $infos[$linkageid]['name'],'url'=>$urlrule));if($infos[$linkageid]['parentid']){return get_parent_url($modelid,$field,$infos[$linkageid]['parentid'],$array);}return $array;}
/*** 构造筛选时候的sql语句*/
function structure_filters_sql($modelid) {$sql = $fieldname = $min = $max = '';$fieldvalue = array();$modelid = intval($modelid);$model =  getcache('model','commons');$fields = getcache('model_field_'.$modelid,'model');$fields_key = array_keys($fields);//TODO$sql = '`status` = \'99\'';foreach ($_GET as $k=>$r) {if(in_array($k,$fields_key) && intval($r)!=0 && ($fields[$k]['filtertype'] || $fields[$k]['rangetype'])) {if($fields[$k]['formtype'] == 'linkage') {$datas = getcache($fields[$k]['linkageid'],'linkage');$infos = $datas['data'];if($infos[$r]['arrchildid']) {$sql .=  ' AND `'.$k.'` in('.$infos[$r]['arrchildid'].')';}} elseif($fields[$k]['rangetype']) {if(is_numeric($r)) {$sql .=" AND `$k` = '$r'";} else {$fieldvalue = explode('_',$r);$min = intval($fieldvalue[0]);$max = $fieldvalue[1] ? intval($fieldvalue[1]) : 999999;$sql .=" AND `$k` >= '$min' AND  `$k` < '$max'";}} else {$sql .=" AND `$k` = '$r'";}}}return $sql;}/*** 分页,如去掉则分页会有问题*/
function makeurlrule() {if(strpos(URLRULE,'.html') === FALSE) {return url_par('page={$'.'page}');}else {$url = preg_replace('/-[0-9]+.html$/','-{$page}.html',get_url());return $url;}
}?>

然后,内容——模型管理——选择一个模型添加新字段   如图

然后,在要调用产品筛选的栏目模板页添加标签  如下。。。

<span>性别:</span>
{loop filters('xingbie',$modelid) $r}
{$r[menu]}
{/loop}

{php $sql = structure_filters_sql($modelid)}
{php $urlrule = makeurlrule()}{pc:content action="lists" where="$sql" catid="$catid" num="10" order="id DESC" page="$page"  urlrule="$urlrule"}<ul class="photo-list picbig">{loop $data $r}<li><div class="img-wrap"><a href="{$r[url]}"><img src="{thumb($r[thumb],150,112)}" width="150" height="112" alt="{$r[title]}"/></a></div><span style="color:{$r[style]}">{str_cut($r[title],28)}</span></li>{/loop}</ul><div id="pages" class="text-c">{$pages}</div>{/pc}

想加什么筛选条件自己可以随便添加,注意字段名

转载于:https://www.cnblogs.com/yuan9580/p/10592804.html

PHPCMS的产品筛选功能相关推荐

  1. phpcms教程:phpcms v9 筛选功能的图文教程

    在本文最后有此文章涉及的相关文件的下载 效果展示: 实现方法: 添加字段: 后台-->内容-->内容相关设置-->模型管理-->文章模型-->字段管理-->添加字段 ...

  2. 【PHP开源产品】Ecshop的商品筛选功能实现分析之一(主要对category.php进行分析)

    [PHP开源产品]Ecshop的商品筛选功能实现分析之一(主要对category.php进行分析) 一.首先,说明一下为什么要对category.php文件进行分析. (1)原因如下: ①个人对商城类 ...

  3. 【PHP开源产品】Ecshop的商品筛选功能实现分析之一

    一.首先,说明一下为什么要对category.php文件进行分析. 原因如下: ①个人对商城类商品筛选功能的实现比较好奇: ②对商城中关于商品的数据表设计比较感兴趣.(该功能涉及到与数据库的交互,而且 ...

  4. PHP实现列表页综合筛选功能,dede织梦列表页联动筛选方法功能的实现

    [DEDECMS.织梦开源程序已经成为市场上主流仿站开源代码,它能够非常快速的放置一个已经建立好的网站,但是前提是这些网站比较简单,没有一些复杂的功能,那么使用DEDECMS仿站是最快速,最有效的.而 ...

  5. 判断作弊 牛客 编程_牛客企业服务产品-新功能速递-第5期

    <牛客企业服务产品功能速递> 栏目,旨在帮 助企业用户及时了解牛客企业服务产品功能更新/新增,让用户第一时间了解和使用我们的新产品/功能.锁定<牛客企业服务产品新功能速递>,我 ...

  6. 织梦DedeCMS列表页多条件联动筛选功能(移动端列表页使用电脑端模板问题解决)

    原文:http://www.dedejs.com/html/article-571-1.html点击打开链接 备注:按此文可以解决,但手机列表页会出问题.列表页移动端调用的还是电脑端模板. 此问题本人 ...

  7. php织梦二次开发的功能例子,织梦DedeCMS二次开发联动筛选功能的实现(含多选功能)...

    织梦默认的列表页没有筛选功能,但有时候我们做产品列表页的时候,产品的字段比较多,很多人都需要用到筛选功能,这样可以让用户更方便的找到自己所需要的东西,实现这个联动筛选功能需要对织梦进行二次开发,下面就 ...

  8. “探探照片墙筛选”功能浅析

    探探,一个主打线上异性交友的一款社交App. 2014年6月,探探 iOS和Android版本上线 2016年11月,探探日活跃用户超过500万.总共完成近60亿次配对. 2018年2月23日,陌陌以 ...

  9. 查询两张表 然后把数据并在一起_工作表数据查询时,类似筛选功能LIKE和NOT LIKE的应用...

    大家好,我们继续讲解VBA数据库解决方案,今日讲解第53讲内容:工作表查询时,类似于筛选功能的LIKE和NOT LIKE 的应用.大家在工作的时候,利用EXCEL操作,筛选是必不可少的工具之一.例如我 ...

最新文章

  1. python不定长参数举例说明_Python的不定长参数
  2. Qt字符串与整形转换
  3. inotifywait实现目录监控
  4. hive性能优化指南
  5. My favorite books
  6. C#中NULL,,DBNULL,String.Empty,Convert.IsDBNull()的区别
  7. Javaimport以及Java类的搜索路径
  8. scipy —— 丰富的子包(io、cluster)
  9. mysql 备份还原策略_Mysql备份恢复
  10. [异步图书].精通Python自然语言处理 pdf
  11. WPS安装office自定义项安装期间出错
  12. mac charles4.0.2免费破解版安装
  13. NBA30只球队2020年各队数据分析
  14. obs 推流编码在哪设置_在OBS上进行H265推流
  15. Windows 环境变量工具 Evn
  16. 可怕,任天堂找到了一种新的赚钱方式……​
  17. linux hba查看,各操作系统查看HBA和WWN的方法
  18. Android AVD Manager - 安卓虚拟机的设置
  19. C#中Newtonsoft.Json(Json.NET)的使用
  20. 盛邦安全发布首个网络空间地图——网络空间坤舆图,为新基建提供数字安全底图

热门文章

  1. (转)利用MS AJAX 扩展服务器端控件
  2. 控制台资费管理主菜单java_java毕业设计_springboot框架的高速公路收费管理系统...
  3. react 判断图片是否加载完成_React中型项目的优化实践
  4. 转义字符的使用和功能python_Python中转义符和格式符的混合使用,python,转义字符,与,格式化...
  5. mysql数据库应用的权限层级_MySQL数据库的用户权限管理
  6. maven exclude java_java – Maven:从shade插件中排除依赖项
  7. android adb杀死服务,Android app是如何杀掉的
  8. html5css3js文件作业,HTML5 CSS3 JavaScriptWeb前端开发自测试卷2.docx
  9. webservice接口_webservice服务器端发票识别接口
  10. Win32汇编学习[7]: 定义符号常量(=、EQU、TEXTEQU)