phpcms (通用)筛选分类

如下图所示功能:



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

  1. <?php  
  2. /** 
  3.  *  extention.func.php 用户自定义函数库 
  4.  * 
  5.  * @copyright           (C) 2005-2010 PHPCMS 
  6.  * @license             http://www.phpcms.cn/license/ 
  7.  * @lastmodify          2010-10-27 
  8.  */  
  9.    
  10.   
  11.  /** 
  12.  * 通过指定keyid形式显示所有联动菜单 
  13.  * @param  $keyid 菜单主id 
  14.  * @param  $linkageid  联动菜单id,0调用顶级 
  15.  * @param  $modelid 模型id 
  16.  * @param  $fieldname  字段名称 
  17.  */  
  18. function show_linkage($keyid$linkageid = 0, $modelid = ''$fieldname='zone') {  
  19.         $datas = $infos = $array = array();  
  20.         $keyid = intval($keyid);  
  21.         $linkageid = intval($linkageid);  
  22.         //当前菜单id  
  23.         $field_value = intval($_GET[$fieldname]);  
  24.         $urlrule = structure_filters_url($fieldname,$array,1,$modelid);  
  25.         if($keyid == 0) return false;  
  26.         $datas = getcache($keyid,'linkage');  
  27.         $infos = $datas['data'];  
  28.   
  29.         foreach($infos as $k=>$v){  
  30.                 if($v['parentid']==$field_value){  
  31.                         $array[$k]['name'] = $v['name'];  
  32.                         $array[$k]['value'] = $k;  
  33.                         $array[$k]['url'] = str_replace('{'.$fieldname.'}',$k,$urlrule);  
  34.                         $array[$k]['menu'] = $field_value == $k ? '<em>'.$v['name'].'</em>' : '<a href='.$array[$k]['url'].'>'.$v['name'].'</a>' ;  
  35.                         }  
  36.                         }  
  37.                         return $array;  
  38.                         }  
  39.                           
  40. /** 
  41.  * 构造筛选URL 
  42.  */                       
  43. function structure_filters_url($fieldname,$array=array(),$type = 1,$modelid) {  
  44.         if(empty($array)) {  
  45.                 $array = $_GET;  
  46.                 } else {  
  47.                         $array = array_merge($_GET,$array);  
  48.                         }  
  49.         //TODO  
  50.         $fields = getcache('model_field_'.$modelid,'model');  
  51.         if(is_array($fields) && !empty($fields)) {  
  52.                         ksort($fields);  
  53.                         foreach ($fields as $_v=>$_k) {  
  54.                                 if($_k['filtertype'] || $_k['rangetype']) {  
  55.                                         if(strpos(URLRULE,'.html') === FALSE) $urlpars .= '&'.$_v.'={$'.$_v.'}';  
  56.                                         else $urlpars .= '-{$'.$_v.'}';  
  57.                                         }  
  58.                                         }  
  59.                                         }  
  60.         //后期增加伪静态等其他url规则管理,apache伪静态支持9个参数  
  61.         if(strpos(URLRULE,'.html') === FALSE) $urlrule =APP_PATH.'index.php?m=content&c=index&a=lists&catid={$catid}'.$urlpars.'&page={$page}' ;  
  62.         else $urlrule =APP_PATH.'list-{$catid}'.$urlpars.'-{$page}.html';  
  63.         //根据get传值构造URL  
  64.         if (is_array($array)) foreach ($array as $_k=>$_v) {  
  65.                         if($_k=='page'$_v=1;  
  66.                         if($type == 1) if($_k==$fieldnamecontinue;  
  67.                         $_findme[] = '/{\$'.$_k.'}/';  
  68.                         $_replaceme[] = $_v;  
  69.                         }  
  70.      //type 模式的时候,构造排除该字段名称的正则  
  71.         if($type==1) $filter = '(?!'.$fieldname.'.)';  
  72.         $_findme[] = '/{\$'.$filter.'([a-z0-9_]+)}/';  
  73.         $_replaceme[] = '';  
  74.         $urlrule = preg_replace($_findme$_replaceme$urlrule);  
  75.         return         $urlrule;  
  76. }  
  77.   
  78. /** 
  79.  * 生成分类信息中的筛选菜单 
  80.  * @param $field   字段名称 
  81.  * @param $modelid  模型ID 
  82.  */  
  83. function filters($field,$modelid,$diyarr = array()) {  
  84.         $fields = getcache('model_field_'.$modelid,'model');  
  85.         $options = empty($diyarr) ?  explode("\n",$fields[$field]['options']) : $diyarr;  
  86.         $field_value = intval($_GET[$field]);  
  87.         foreach($options as $_k) {  
  88.                 $v = explode("|",$_k);  
  89.                 $k = trim($v[1]);  
  90.                 $option[$k]['name'] = $v[0];  
  91.                 $option[$k]['value'] = $k;  
  92.                 $option[$k]['url'] = structure_filters_url($field,array($field=>$k),2,$modelid);  
  93.                 $option[$k]['menu'] = $field_value == $k ? '<em>'.$v[0].'</em>' : '<a href='.$option[$k]['url'].'>'.$v[0].'</a>' ;  
  94.         }  
  95.         $all['name'] = '全部';  
  96.         $all['url'] = structure_filters_url($field,array($field=>''),2,$modelid);  
  97.         $all['menu'] = $field_value == '' ? '<em>'.$all['name'].'</em>' : '<a href='.$all['url'].'>'.$all['name'].'</a>';  
  98.   
  99.         array_unshift($option,$all);  
  100.         return $option;  
  101. }  
  102.   
  103. /** 
  104.  * 获取联动菜单层级 
  105.  * @param  $keyid     联动菜单分类id 
  106.  * @param  $linkageid 菜单id 
  107.  * @param  $leveltype 获取类型 parentid 获取父级id child 获取时候有子栏目 arrchildid 获取子栏目数组 
  108.  */  
  109. function get_linkage_level($keyid,$linkageid,$leveltype = 'parentid') {  
  110.         $child_arr = $childs = array();  
  111.         $leveltypes = array('parentid','child','arrchildid','arrchildinfo');  
  112.         $datas = getcache($keyid,'linkage');  
  113.         $infos = $datas['data'];  
  114.         if (in_array($leveltype$leveltypes)) {  
  115.                 if($leveltype == 'arrchildinfo') {  
  116.                         $child_arr = explode(',',$infos[$linkageid]['arrchildid']);  
  117.                         foreach ($child_arr as $r) {  
  118.                                 $childs[] = $infos[$r];  
  119.                         }  
  120.                         return $childs;  
  121.                 } else {  
  122.                         return $infos[$linkageid][$leveltype];  
  123.                 }  
  124.         }          
  125. }  
  126.   
  127. // 根据linkageid递归到父级  
  128. function get_parent_url($modelid,$field,$linkageid=0,$array = array()){  
  129.         $modelid = intval($modelid);  
  130.         if(!$modelid || empty($field)) return false;  
  131.         $fields = getcache('model_field_'.$modelid,'model');  
  132.         $keyid = $fields[$field]['linkageid'];  
  133.         $datas = getcache($keyid,'linkage');  
  134.         $infos = $datas['data'];  
  135.                   
  136.         if(empty($linkageid)){  
  137.                 $linkageid = intval($_GET[$field]);  
  138.                 if(!$linkageidreturn false;  
  139.                 }  
  140.                   
  141.                 $urlrule = structure_filters_url($field,array(),1,$modelid);  
  142.                 $urlrule = str_replace('{$'.$field.'}',$infos[$linkageid]['parentid'],$urlrule);  
  143.                 array_unshift($array,array('name'=> $infos[$linkageid]['name'],'url'=>$urlrule));  
  144.                 if($infos[$linkageid]['parentid']){  
  145.                         return get_parent_url($modelid,$field,$infos[$linkageid]['parentid'],$array);  
  146.                         }  
  147.                         return $array;  
  148.                         }  
  149. /** 
  150.  * 构造筛选时候的sql语句 
  151.  */  
  152. function structure_filters_sql($modelid) {  
  153.         $sql = $fieldname = $min = $max = '';  
  154.         $fieldvalue = array();  
  155.         $modelid = intval($modelid);  
  156.         $model =  getcache('model','commons');  
  157.         $fields = getcache('model_field_'.$modelid,'model');  
  158.         $fields_key = array_keys($fields);  
  159.         //TODO  
  160.         $sql = '`status` = \'99\'';  
  161.         foreach ($_GET as $k=>$r) {  
  162.                 if(in_array($k,$fields_key) && intval($r)!=0 && ($fields[$k]['filtertype'] || $fields[$k]['rangetype'])) {  
  163.                         if($fields[$k]['formtype'] == 'linkage') {  
  164.                                 $datas = getcache($fields[$k]['linkageid'],'linkage');  
  165.                                 $infos = $datas['data'];  
  166.                                 if($infos[$r]['arrchildid']) {  
  167.                                         $sql .=  ' AND `'.$k.'` in('.$infos[$r]['arrchildid'].')';  
  168.                                         }  
  169.                                         } elseif($fields[$k]['rangetype']) {  
  170.                                                 if(is_numeric($r)) {  
  171.                                                         $sql .=" AND `$k` = '$r'";  
  172.                                                         } else {  
  173.                                                                 $fieldvalue = explode('_',$r);  
  174.                                                                 $min = intval($fieldvalue[0]);  
  175.                                                                 $max = $fieldvalue[1] ? intval($fieldvalue[1]) : 999999;  
  176.                                                                 $sql .=" AND `$k` >= '$min' AND  `$k` < '$max'";  
  177.                                                                 }  
  178.                                                                 } else {  
  179.                                                                         $sql .=" AND `$k` = '$r'";  
  180.                                                                         }  
  181.                                                                         }  
  182.                                                                         }  
  183.                                                                         return $sql;  
  184.                                                                         }  
  185.   
  186. /** 
  187.  * 分页,如去掉则分页会有问题 
  188.  */  
  189. function makeurlrule() {  
  190.         if(strpos(URLRULE,'.html') === FALSE) {  
  191.                 return url_par('page={$'.'page}');  
  192.         }  
  193.         else {  
  194.                 $url = preg_replace('/-[0-9]+.html$/','-{$page}.html',get_url());  
  195.                 return $url;  
  196.         }  
  197. }  
  198.   
  199.    
  200. ?>  

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


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

[html] view plain copy
  1. <span>性别:</span>    
  2. {loop filters('xingbie',$modelid) $r}  
  3. {$r[menu]}  
  4. {/loop}  

[html] view plain copy
  1. {php $sql = structure_filters_sql($modelid)}  
  2. {php $urlrule = makeurlrule()}  
  3.     {pc:content action="lists" where="$sql" catid="$catid" num="10" order="id DESC" page="$page"  urlrule="$urlrule"}  
  4.       
  5.         <ul class="photo-list picbig">  
  6.             {loop $data $r}  
  7.             <li>  
  8.             <div class="img-wrap">  
  9.             <a href="{$r[url]}"><img src="{thumb($r[thumb],150,112)}" width="150" height="112" alt="{$r[title]}"/></a>  
  10.             </div>  
  11.             <span style="color:{$r[style]}">{str_cut($r[title],28)}</span>  
  12.             </li>  
  13.             {/loop}  
  14.         </ul>  
  15.         <div id="pages" class="text-c">{$pages}</div>  
  16.     {/pc} 

猜你喜欢

转载自blog.csdn.net/qq_39376608/article/details/80267956