phpcms筛选功能的图文教程
[ 2016/01/21, Phpcms , 5513阅, 14评 ]

phpcms筛选功能.jpg

实现方法:

添加字段: 后台-->内容-->内容相关设置-->模型管理-->文章模型-->字段管理-->添加字段-->如下图示例:

phpcms筛选配置.jpg

添加自定义函数:

将以下代码添加到 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;
            }
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传值构造URL
        if (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语句,jianggle解决直接筛选出该模型下的所有内容的问题,改成同模型下的栏目间互相独立
 */
function structure_filters_sql($modelid,$catid) {//增加了$catid参数
    $sql = $fieldname = $min = $max = '';
    $fieldvalue = array();
    $modelid = intval($modelid);
	$catid = intval($catid);
    $model =  getcache('model','commons');
    $fields = getcache('model_field_'.$modelid,'model');
    $fields_key = array_keys($fields);
    //TODO
    $sql = '`status` = \'99\'';
    if($catid!=0)  $sql .= ' AND `catid`=\''.$catid.'\'';//同模型,不同catid
    foreach ($_GET as $k=>$r) {
        if(in_array($k,$fields_key) && intval($r)!=0 && ($fields[$k]['filtertype'] || $fields[$k]['rangetype']|| $fields[$k]['boxtype'])) {
            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'";
                        }
            }elseif($fields[$k]['boxtype']=='checkbox') {
                   $sql .=" AND `$k` like '%,$r,%'";

            } else {
                   $sql .=" AND `$k` = '$r'";
            }
        }
    }
   // echo $sql;
   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;
    }
}


/********************实现前台输出“选项名称”功能************************/
/**
* 根据box类型字段获取显示名称
* @param $field 字段名称
* @param $value 字段值
* @param $modelid 字段所在模型id
*/
function box($field, $value, $modelid='') {
        $fields = getcache('model_field_'.$modelid,'model');
        extract(string2array($fields[$field]['setting']));
        $options = explode("\n",$fields[$field]['options']);
        foreach($options as $_k) {
                $v = explode("|",$_k);
                $k = trim($v[1]);
                $option[$k] = $v[0];
        }
        $string = '';
        switch($fields[$field]['boxtype']) {
                        case 'radio':
                                $string = $option[$value];
                        break;
                        case 'checkbox':
                                $value_arr = explode(',',$value);
                                foreach($value_arr as $_v) {
                                        if($_v) $string .= $option[$_v].' 、';
                                }
                        break;

                        case 'select':
                                $string = $option[$value];
                        break;

                        case 'multiple':
                                $value_arr = explode(',',$value);
                                foreach($value_arr as $_v) {
                                        if($_v) $string .= $option[$_v].' 、';
                                }
                        break;
                }
                        return $string;
}

?>

模板使用

{template "content","header"}
<!--main-->
<div class="main">
    <div class="col-left">
        <div class="crumbs"><a href="{siteurl($siteid)}">首页</a><span> > </span>{catpos($catid)} 列表</div>
{php $sql = structure_filters_sql($modelid,$catid)}
{php $urlrule = makeurlrule()}
{pc:content action="lists" catid="$catid" where="$sql" num="3" order="id DESC" page="$page" moreinfo="1" urlrule="$urlrule"}
<ul>
    {loop $data $r}
    <li>
        <h2><a href="{$r[url]}" title="{$r[title]}" target="_blank">{$r[title]}</a></h2>
        性别:{box('sex',$r[sex],$modelid)} 学历:{box('edu',$r[edu],$modelid)}
    </li>
    {/loop}
</ul>
<div id="pages" class="text-c">{$pages}</div>
{/pc}
    </div>
    <div class="col-auto">
        <div class="box">
            <h5 class="title-2">性别</h5>
            <ul class="content digg">
{loop filters('sex',$modelid) $r}
<li>{$r[menu]} </li>
{/loop}
            </ul>
        </div>
        <div class="bk10"></div>
        <div class="box">
            <h5 class="title-2">学历</h5>
            <ul class="content digg">
{loop filters('edu',$modelid) $r}
<li>{$r[menu]} </li>
{/loop}
            </ul>
        </div>
        <div class="bk10"></div>
    </div>
</div>
{template "content","footer"}

调用解析

pc标签调用筛选后的结果代码:

{php $sql = structure_filters_sql($modelid,$catid)}
{php $urlrule = makeurlrule()}
{pc:content action="lists" catid="$catid" where="$sql" num="3" order="id DESC" page="$page" moreinfo="1" urlrule="$urlrule"}

输出自定义字段的选项名称代码:

{box('sex',$r[sex],$modelid)}  //sex为添加的自定义字段 $modelid为模型id号

调用筛选字段并展现代码:

{loop filters('sex',$modelid) $r} //sex为添加的自定义字段 $modelid为模型id号
<li>{$r[menu]}</li>
{/loop}

有朋自远方来...评论一下呗O(∩_∩)O

  • 评论(14)

    bin012 [ 回复 ]
    2020-04-29 13:23

    如果有做筛选的可以看看这篇文章,http://www.bin012.com/?p=591 这是一篇新手就能搞定的筛选文章

    bin012 [ 回复 ]
    2020-07-04 09:11

    @bin012:看不懂本文的可以参考这个链接http://www.bin012.com/adj/22.html

    大强子 博主大人 [ 回复 ]
    2020-07-04 22:35

    @bin012:赞一个

    bin012 [ 回复 ]
    2020-04-29 09:18

    首先,bug很多,,也许是我菜。其次,我在网上找了很多,都是一样的代码,
    最后我说下bug。
    1.我后台添加字段是对的,前台也能调用,但是选择后是list--1--.html,因为我URL做的是静态,所以打不开。(SEO要求静态)
    2.分页链接错误,我点了和后台批量刷新栏目页效果一样,由于不能上传图片不好展示
    3.为啥不能做成a=1&b=1&c=1.html

    大强子 博主大人 [ 回复 ]
    2020-04-29 13:57

    @bin012:好久没用phpcms了,,,听说官方都关站了样。

    天天天晴 [ 回复 ]
    2018-12-03 15:49

    首页是不是用不了啊

    大强子 博主大人 [ 回复 ]
    2018-12-04 10:57

    @天天天晴:这个我还没试过,不过理论上是能用的,你把modelid和catid换成固定的值试试呢。

    天天天晴 [ 回复 ]
    2018-12-04 13:13

    @天天天晴:换了显示您没有访问该信息的权限!

    大强子 博主大人 [ 回复 ]
    2018-12-05 22:36

    @天天天晴:这是因为直接把它用在首页之后,筛选条件构造出来的url中缺少了catid的值,首页是拿不到这玩意儿的,构造url的函数名叫structure_filters_url你想办法把它改改就行了。顺便提醒下,还有个分页问题O(∩_∩)O哈哈~祝好运!

    鼎宏设计 [ 回复 ]
    2018-06-20 16:29

    你好,我按照上面的操作了以后(加了$catid),但是无法掉出数据,如果不用$catid的话,调出的是整个模型的数据,能帮我看看不?

    大强子 博主大人 [ 回复 ]
    2018-06-20 16:39

    @鼎宏设计:具体什么情况?

    大强子 博主大人 [ 回复 ]
    2018-06-20 23:31

    @鼎宏设计:专门下班回去再次测试了下,以上代码无论是在我16年用的9.5.10_UTF8版本和我现在用的9.6.3_UTF8版本都是没有问题的。关于“不用$catid的话,调出的是整个模型的数据”,该筛选方案原作者最开始实现的就是这样的效果的,然后因为项目需要我才加了catid来控制同模型下的分类筛选问题。你再仔细检查下是否是其他的问题吧?我的php水平也不啥行,可能帮不上什么忙了,哈哈,祝好运!

    鼎宏设计 [ 回复 ]
    2018-06-21 09:14

    @e起飞young:你好,昨天我又研究了下,发现了问题了,主要是lists标签中,加上where后其他条件失效,我修改了/phpcms/modules/content/classes/目录下的content_tag.class.php这个文件,后面就可以了,谢谢你的帮忙!

    小五 [ 回复 ]
    2017-11-18 19:51

    请教一下伪静态的问题 你文章中的伪静态后展示位 list-{$catid}-1-1-{$page}.html    我想改成 /exhibition/huipei/list-1-1-{$page}.html

    请问规则应该怎么写呢