织梦DEDE分类信息实现联动筛选(支持多条件多级选项)解决方案

一、联动筛选单选功能

很多织梦建站的站长在做产品列表页的时候,产品分类多而且都是关联的,用户不能快速的找到自己需要的东西,很多情况下都需要用到筛选功能,织梦后台列表页默认是没有联动筛选功能,实现这个联动筛选功能需要对织梦进行二次开发,接下来教大家如何实现这个联动筛选功能,如下图所示:

:因为织梦默认是禁止使用php标签,所以需要在后台模板引擎禁用标签里面解除这个标签的禁用,具体方法:

后台——系统——系统基本参数——其它选项——模板引擎禁用标签:php

将这个PHP去掉后保存就可以了!

第一步:打开arc.listview.class.php 找到:if(empty($cfg_need_typeid2)) $cfg_need_typeid2 = 'N';
在下面加入以下代码:

//联动筛选获得附加表的相关信息

$addtable  = $this->ChannelUnit->ChannelInfos['addtable'];

if($addtable!="")

{

$addJoin = " LEFT JOIN `$addtable` ON arc.id = ".$addtable.'.aid ';

$addField = '';

$fields = explode(',',$this->ChannelUnit->ChannelInfos['listfields']);

foreach($fields as $k=>$v)

{

$nfields[$v] = $k;

}

if(is_array($this->ChannelUnit->ChannelFields) && !empty($this->ChannelUnit->ChannelFields))

{

foreach($this->ChannelUnit->ChannelFields as $k=>$arr)

{

if(isset($nfields[$k]))

{

if(!empty($arr['rename'])) {

$addField .= ','.$addtable.'.'.$k.' as '.$arr['rename'];

}

else {

$addField .= ','.$addtable.'.'.$k;

}

}

}

}

if (isset($_REQUEST['tid']))

{

foreach($_GET as $key => $value) {

$filtersql .= ($key!="tid" && $key!="TotalResult" && $key!="PageNo") ? " AND $addtable.".wwwcms_filter($key)." = '".wwwcms_filter(urldecode($value))."'" : '';

}

}

}

else

{

$addField = '';

$addJoin = '';

}



第二步:打开extend.func.php文件在底部加入以下代码:

/*联动筛选字符过滤函数*/

function wwwcms_filter($str,$stype="inject") {

  if ($stype=="inject")  {

   $str = str_replace(

          array( "select", "insert", "update", "delete", "alter", "cas", "union", "into", "load_file", "outfile", "create", "join", "where", "like", "drop", "modify", "rename", "'", "/*", "*", "../", "./"),

       array("","","","","","","","","","","","","","","","","","","","","",""),

       $str);

  } else if ($stype=="xss") {

   $farr = array("/\s+/" ,

                 "/<(\/?)(script|META|STYLE|HTML|HEAD|BODY|STYLE |i?frame|b|strong|style|html|img|P|o:p|iframe|u |em|strike|BR|div|a|TABLE|TBODY|object|tr|td |st1:chsdate|FONT|span|MARQUEE|body|title |\r\n|link |meta|\?|\%)([^>]*?)>/isU",

        "/(<[^>]*)on[a-zA-Z]+\s*=([^>]*>)/isU",

        );

   $tarr = array(" ",

                 "",

        "\\1\\2",

        );

   $str = preg_replace($farr, $tarr, $str);

   $str = str_replace(

          array( "<", ">", "'", "\"", ";", "/*", "*", "../", "./"),

       array("&lt;","&gt;","","","","","","",""),

       $str);

  }

  return $str;

 }



/**

  *  载入自定义表单(用于发布)

  *

  * @access    public

  * @param     string  $fieldset  字段列表

 * @param     string  $loadtype  载入类型

 * @return    string

  */



 function AddFilter($channelid, $type=1, $fieldsnamef, $defaulttid, $loadtype='autofield')

 {

  global $tid,$dsql,$id;

  $tid = $defaulttid ? $defaulttid : $tid;

  if ($id!="")

  {

   $tidsq = $dsql->GetOne(" Select typeid From `dede_archives` where id='$id' ");

   $tid = $tidsq["typeid"];

  }

  $nofilter = (isset($_REQUEST['TotalResult']) ? "&TotalResult=".$_REQUEST['TotalResult'] : '').(isset($_REQUEST['PageNo']) ? "&PageNo=".$_REQUEST['PageNo'] : '');

  $filterarr = wwwcms_filter(stripos($_SERVER['REQUEST_URI'], "list.php?tid=") ? str_replace($nofilter, '', $_SERVER['REQUEST_URI']) : $GLOBALS['cfg_cmsurl']."/plus/list.php?tid=".$tid);

     $cInfos = $dsql->GetOne(" Select * From  `dede_channeltype` where id='$channelid' ");

  $fieldset=$cInfos['fieldset'];

  $dtp = new DedeTagParse();

     $dtp->SetNameSpace('field','<','>');

     $dtp->LoadSource($fieldset);

     $dede_addonfields = '';

     if(is_array($dtp->CTags))

     {

         foreach($dtp->CTags as $tid=>$ctag)

         {

             $fieldsname = $fieldsnamef ? explode(",", $fieldsnamef) : explode(",", $ctag->GetName());

    if(($loadtype!='autofield' || ($loadtype=='autofield' && $ctag->GetAtt('autofield')==1)) && in_array($ctag->GetName(), $fieldsname) )

             {

                 $href1 = explode($ctag->GetName().'=', $filterarr);

     $href2 = explode('&', $href1[1]);

     $fields_value = $href2[0];

     $dede_addonfields .= '<dl><dt>'.$ctag->GetAtt('itemname').':</dt><dd>';

     switch ($type) {

      case 1:

       $dede_addonfields .= (preg_match("/&".$ctag->GetName()."=/is",$filterarr,$regm) ? '<a  title="全部" href="'.str_replace("&".$ctag->GetName()."=".$fields_value,"",$filterarr).'">全部</a>' : '<dd><a class="on">全部</a>').'';

     

       $addonfields_items = explode(",",$ctag->GetAtt('default'));

       for ($i=0; $i<count($addonfields_items); $i++)

       {

        $href = stripos($filterarr,$ctag->GetName().'=') ? str_replace("=".$fields_value,"=".urlencode($addonfields_items[$i]),$filterarr) : $filterarr.'&'.$ctag->GetName().'='.urlencode($addonfields_items[$i]);//echo $href;

        $dede_addonfields .= ($fields_value!=urlencode($addonfields_items[$i]) ? '<a  title="'.$addonfields_items[$i].'" href="'.$href.'">'.$addonfields_items[$i].'</a>' : '<a class="on">'.$addonfields_items[$i].'</a>');

       }

       $dede_addonfields .= '</dd></dl>';

      break;

     

      case 2:

       $dede_addonfields .= '<select name="filter"'.$ctag->GetName().' onchange="window.location=this.options[this.selectedIndex].value">

        '.'<option value="'.str_replace("&".$ctag->GetName()."=".$fields_value,"",$filterarr).'">全部</option>';

       $addonfields_items = explode(",",$ctag->GetAtt('default'));

       for ($i=0; $i<count($addonfields_items); $i++)

       {

        $href = stripos($filterarr,$ctag->GetName().'=') ? str_replace("=".$fields_value,"=".urlencode($addonfields_items[$i]),$filterarr) : $filterarr.'&'.$ctag->GetName().'='.urlencode($addonfields_items[$i]);

        $dede_addonfields .= '<option value="'.$href.'"'.($fields_value==urlencode($addonfields_items[$i]) ? ' selected="selected"' : '').'>'.$addonfields_items[$i].'</option>

        ';

       }

       $dede_addonfields .= '</select><br/>

       ';

      break;

     }

             }

         }

     }

  echo $dede_addonfields;

 }

第三步:到这里PHP文件修改的部分就完成了!接下来就需要给指定的模型添加字段了,这里需要注意的就是 字段类型的选择,字段类型需要选择单选按钮或者使用select下拉框,如下图所示:

第四部: 前台调用标签

{dede:php}AddFilter(3,1,'fenleia,fenleib,fenleic');{/dede:php}

注:标签说明:

AddFilter函数里面的第一个数字3是内容模型的id号,各个内容模型的id请到后台内容模型管理里面查看;

第二个数字1是表示筛选的样式,1是使用超链接进行选择,2是使用select下拉框选择,具体可以自己设置了查看效果;

第三个部分'fenleia,fenleib,fenleic'是要添加筛选功能的字段名,这里有3个字段,注意需要用半角逗号隔开。

===============================================================================

如果您像我一样的懒惰,哈哈,以下有整理好的文件提供下载

点击此处下载文件  提取码:oax0

点击下处下载说明  提取码:8czq

===============================================================================

二、联动筛选多选功能

搜索情况类似下图:每个自定义字段值能选择N个值(url不能超过255个字符)

然后打开之前修改过的arc.listview.class.php文件,分别在第177行左右和第809行的左右的样子,找到如下代码:

$filtersql .= ($key!="tid" && $key!="TotalResult" && $key!="PageNo") ? " AND $addtable.".wwwcms_filter($key)." = ".wwwcms_filter(iconv("UTF-8", "gb2312", $value))."" : ";

两处的代码都修改为下面的代码:

if($key=="goodstype" || $key=="goodscolor" ){//你自定义字段的字段名(英文的那个name)
		$count=0;
		$nowsql ='';
		$var=explode(",",wwwcms_filter(iconv("UTF-8", "gb2312", $value)));//iconv是转码的意思,如果你url传进来的参数是中文,就需要转码
 
		if(!empty($var)){
			foreach($var as $value){ 
			   if($count==0){
			      $filtersql.="and ($addtable.".wwwcms_filter($key)." like '%".$value."%'";
			      $count++;
			   }else{
			     $filtersql.="or $addtable.".wwwcms_filter($key)." like '%".$value."%'";
			}
 
		     }
		$filtersql.=")";
		}
 
 
	}else{
	$filtersql .= ($key!="tid" && $key!="TotalResult" && $key!="PageNo") ? " AND $addtable.".wwwcms_filter($key)." = ".wwwcms_filter(iconv("UTF-8", "gb2312", $value))."" : '';//跟上面一样,如果传递的值是中文,那么就需要转码
}

然后在前台调用的时候,比如参数是http://xxx.com/plus/list.php?tid=4&goodstype=类型1,类型2&goodscolor=灰色,红色,蓝色

 

记住,一定要以英文半角逗号隔开,如果你编码是gbk的,传值的时候如果url显示的是中文,就可以直接使用上面的代码,否则的话在转码那可能要稍微修改下。

注:在首页调用该标签时,需要在后面加上栏目ID

首页调用方法
{dede:php}AddFilter(模型ID,类型,"字段1",栏目id);{/dede:php}
    
内容页调用方法
{dede:php}AddFilter(模型ID,类型,"字段1",栏目id,1);{/dede:php}

筛选结果数据显示只支持dede:list

{dede:list pagesize='10'}{/dede:list}

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值