[转藏]最新织梦DedeCMS二次开发联动筛选功能的实现(单选和多选)可显示分类的文章数量

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

更新说明:之前版本修改arc.listview.class.php文件后,导致手机端无法加载_m.htm列表模板,新版已修复此bug,请【点击这里】下载新版文件使用。

下面就告诉大家如何对织梦进行二次开发实现这个很多人都需要的筛选功能,先上效果图:

[转藏]最新织梦DedeCMS二次开发联动筛选功能的实现(单选和多选)可显示分类的文章数量_第1张图片

首先需要说明的是这个功能需要在模板里面用到php标签,所以需要在后台模板引擎禁用标签里面解除这个标签的禁用,具体方法:
登录后台 >> 系统 >> 系统基本参数 >> 其它选项 >> 模板引擎禁用标签:php
将这个php删除后保存就可以了!

[转藏]最新织梦DedeCMS二次开发联动筛选功能的实现(单选和多选)可显示分类的文章数量_第2张图片

联动筛选功能分为两种,单选和多选,好了,下面开始正题。

一、联动功能 单选

首先需要修改2个PHP文件,用编辑器打开include目录下的 arc.listview.class.php 和 extend.func.php

1、修改arc.listview.class.php,这个文件改动的地方较多,建议大家直接【点击这里】下载附件压缩包里面的文件,直接替换。
注意:如果你曾经对arc.listview.class.php这个文件进行过改动的话,请先备份原文件,再对比“参照表”逐一手动替换!
打开参照表

2、修改extend.func.php文件,这个文件改动很简单,直接在最后面添加如下代码:
特别注意:以下代码中有4处“【分隔符】”字样,请自行删除。

// 字符过滤函数  ( 织梦OK www.dedecmsok.com )
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("<",">","","","","","","",""),
       $str);
  }
  return $str;
 }
//  织梦OK www.dedecmsok.com
//  载入自定义表单(用于发布)
//  @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 `#【分隔符】@__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  `#【分隔符】@__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 .= '
'.$ctag->GetAtt('itemname').':'; switch ($type) { case 1: $dedecmsoka = $ctag->GetName(); $dederow = $dsql->GetOne("SELECT count($dedecmsoka) FROM #【分隔符】@__addonarticle WHERE $dedecmsoka"); $dederowz = $dederow["count($dedecmsoka)"]; $dede_addonfields .= (preg_match("/&".$ctag->GetName()."=/is",$filterarr,$regm) ? '.str_replace("&".$ctag->GetName()."=".$fields_value,"",$filterarr).'">全部('.$dederowz.')' : '全部('.$dederowz.')').' '; $addonfields_items = explode(",",$ctag->GetAtt('default')); for ($i=0; $i<count($addonfields_items); $i++) { $dedecmsoka = $ctag->GetName(); $dedecmsokb = $addonfields_items[$i]; $dederow = $dsql->GetOne("SELECT count(*) FROM #【分隔符】@__addonarticle WHERE $dedecmsoka='$dedecmsokb'"); $dederows = $dederow["count(*)"]; $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]) ? '.$addonfields_items[$i].'" href="'.$href.'">'.$addonfields_items[$i].'('.$dederows.')' : ''.$addonfields_items[$i].'('.$dederows.')')." "; } $dede_addonfields .= '
'
; break; case 2: $dede_addonfields .= '