收藏本站 依旧织梦网(19dede.com),专注织梦模板设计制作!
当前位置:主页 > 织梦教程 > 织梦插件 > >

织梦dedecms列表页复合筛选插件教程

时间:2016-09-24 20:37 来源:www.19dede.com 作者:依旧织梦网 阅读:
插件介绍
织梦程序支持文章筛选吗?织梦能做分类信息网站吗?织梦怎样根据条件筛选文章?诸如此类的问题经常看到,今天依旧织梦网就给大家分享下织梦的筛选功能到底怎么做:

织梦默认的列表页是没有筛选功能的,但有时候我们做产品列表页的时候,产品的字段比较多,很多人都需要用到筛选功能,这样可以让用户更方便的找到自己所需要的东西,实现这个联动筛选功能需要对织梦进行二次开发,下面就告诉大家如何对织梦二次开发实现这个很多人都需要的筛选功能,如下图所示:
首先需要说明的是这个功能需要在模板里面用到php标签,所以需要在后台模板引擎禁用标签里面解除这个标签的禁用,具体方法:
后台——系统——系统基本参数——其它选项——模板引擎禁用标签:php
将这个PHP去掉后保存就可以了!注意:如未去掉这个php,那么前台调用的时候会不显示任何内容。

好了,下面开始正题了。

首先需要修改2个PHP文件,都是include目录下面的。

一、修改arc.listview.class.php文件:


在文件中找到
 if(empty($cfg_need_typeid2)) $cfg_need_typeid2 = 'N';
在下方添加:
//获得附加表的相关信息!!此段为添加内容!!!by 依旧织梦网 www.19dede.com
$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 = '';
}
//添加内容结束!!!by 依旧织梦网 www.19dede.com 
找到

 $cquery = "SELECT COUNT(*) AS dd FROM `dede_arctiny` arc WHERE ".$this->addSql;

替换成:

$cquery = "SELECT COUNT(*) AS dd FROM `dede_arctiny` arc $addJoin WHERE ".$this->addSql.$filtersql;//有修改!by 依旧织梦网 www.19dede.com

找到
 }
        else
        {
            $addField = '';
            $addJoin = '';
        }
在上方添加
//此段为添加内容by 依旧织梦网 www.19dede.com 
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))."'" : '';
}
}
//添加内容结束by 依旧织梦网 www.19dede.com 
找到

$query = "SELECT arc.*,tp.typedir,tp.typename,tp.isdefault,tp.defaultname,

           tp.namerule,tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath
           $addField
           FROM `dede_archives` arc
           LEFT JOIN `dede_arctype` tp ON arc.typeid=tp.id
           $addJoin
           WHERE {$this->addSql} $ordersql LIMIT $limitstart,$row";
替换成

$query = "SELECT arc.*,tp.typedir,tp.typename,tp.isdefault,tp.defaultname,

           tp.namerule,tp.namerule2,tp.ispart,tp.moresite,tp.siteurl,tp.sitepath
           $addField
           FROM `dede_archives` arc
           LEFT JOIN `dede_arctype` tp ON arc.typeid=tp.id
           $addJoin
           WHERE {$this->addSql} $filtersql $ordersql LIMIT $limitstart,$row";//本句代码有改动by 依旧织梦网 www.19dede.com 
找到

$query = "SELECT id FROM `dede_arctiny` arc WHERE {$this->addSql} $ordersql LIMIT $limitstart,$row ";

替换成

$query = "SELECT id FROM `dede_arctiny` arc $addJoin WHERE {$this->addSql} $filtersql $ordersql LIMIT $limitstart,$row ";//本句有改动by 依旧织梦网 www.19dede.com 

找到
//$hidenform = "<input type='hidden' name='tid' value='".$this->TypeID."'>\r\n";
//$hidenform .= "<input type='hidden' name='TotalResult' value='".$this->TotalResult."'>\r\n";
在下方添加
//获取筛选参数 此段为添加内容!!!!by 依旧织梦网 www.19dede.com 
foreach($_GET as $key => $value) {
$pageaddurl .= ($key!="tid" && $key!="TotalResult" && $key!="PageNo") ? "&".wwwcms_filter($key)."=".wwwcms_filter($value) : '';
}
//添加内容结束 by 依旧织梦网 www.19dede.com !!!!
找到
$prepage.="<li><a href='".$purl."PageNo=$prepagenum'>上一页</a></li>\r\n";
$indexpage="<li><a href='".$purl."PageNo=1'>首页</a></li>\r\n";
替换成
//改动 by 依旧织梦网 www.19dede.com
$prepage.="<li><a href='".$purl."PageNo=$prepagenum".$pageaddurl."'>上一页</a></li>\r\n";
$indexpage="<li><a href='".$purl."PageNo=1".$pageaddurl."'>首页</a></li>\r\n";
//改动结束
找到
$nextpage.="<li><a href='".$purl."PageNo=$nextpagenum'>下一页</a></li>\r\n";
$endpage="<li><a href='".$purl."PageNo=$totalpage'>末页</a></li>\r\n";
替换成
//改动 by 依旧织梦网 www.19dede.com
$nextpage.="<li><a href='".$purl."PageNo=$nextpagenum".$pageaddurl."'>下一页</a></li>\r\n";
$endpage="<li><a href='".$purl."PageNo=$totalpage".$pageaddurl."'>末页</a></li>\r\n";
//改动结束
这文件改动比较大,建议大家直接下载附件压缩包里面的文件替换,如果你之前对这个文件改动过的话,请在下载下来的压缩包里的这个文件里面搜索有“依旧织梦网”这些注释的这些地方,都是修改过的,然自己手动将有注释的代码插入到自己的文件里面!

二、修改extend.func.php文件


在其最后面添加如下代码:
//dedecms联动筛选功能 By 依旧织梦网 www.19dede.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("&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 .= '<div class="scv-shaixuan"><b>'.$ctag->GetAtt('itemname').':</b>';
     switch ($type) {
      case 1:
       $dede_addonfields .= (preg_match("/&".$ctag->GetName()."=/is",$filterarr,$regm) ? '<a title="全部" href="'.str_replace("&".$ctag->GetName()."=".$fields_value,"",$filterarr).'">全部</a>' : '<span>全部</span>').'&nbsp;';
     
       $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>' : '<span>'.$addonfields_items[$i].'</span>')."&nbsp;";
       }
       $dede_addonfields .= '</div>';
      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(4,1,'linestyle,linethem,youdays,jg');{/dede:php}
标签解释:
  • AddFilter函数里面的第一个数字4是内容模型的id号,各个内容模型的id请到后台内容模型管理里面查看;
  • 第二个数字1是表示筛选的样式,1是使用超链接进行选择,2是使用select下拉框选择,具体可以自己设置了查看效果;
  • 第三个部分'linestyle,linethem,youdays,jg'是要添加筛选功能的字段名,这里有4个字段,注意需要用半角逗号隔开。

注意①:列表页使用 复合筛选 的时候 ,调用文章一定要使用{dede:list pagesize ='12'}{/dede:list}标签,而不是{dede:arclist }{/dede:arclist}标签。否则会出现 选择了筛选条件,文章也不变化的情况。
注意②:上传到空间之后,一定要设置一下空间的php版本,一般是使用php5.4版本。子站尤其注意,子站有单独的设置。空间里一般默认的是不选php版本的,这样会导致筛选的时候筛选条件不能正常的显示样式。西数子站设置图示:

三、核心函数说明


1.模型筛选调用的核心函数写在include下的extend.func.php文件,第24-95行为我们所写的函数,wwwcms_filter函数用于过滤字符,防止sql注入;AddFilter是用来处理筛选过程的函数。

2.真正实现筛选的文件是arc.listview.class.php,主要靠$filtersql这个变量增加查询条件,当没有检测到筛选参数时此变量为空值,不会影响原查询。

3.调用方法说明:
  • 在需要显示筛选的地方加入 {dede:php} AddFilter(模型ID); {/dede:php} 即可,例:{dede:php} AddFilter(1); {/dede:php}。
  • 如果需要以下拉列表的形式筛选,请使用 {dede:php} AddFilter(模型ID,2); {/dede:php} ,例:{dede:php} AddFilter(1,2); {/dede:php}。
  • 如果需要以单选按钮的形式筛选,请使用 {dede:php} AddFilter(模型ID,3); {/dede:php} ,例:{dede:php} AddFilter(1,3); {/dede:php}。
  • 如果要指定使用哪些自定义参数,请使用 {dede:php} AddFilter(1,2,'字段名1,字段名2,字段名3'); {/dede:php} ,例{dede:php} AddFilter(1,2,'chicun,pinpai,star'); {/dede:php}  注意:'chicun,pinpai,star' 是指定的字段名,多个字段用半角逗号分隔。

4.首页调用方法:与第3点一样,但需要多指定一个参数,即默认的栏目id,调用格式是:{dede:php} AddFilter(栏目id,显示类型,'字段名1,字段名2,字段名3……',栏目id); {/dede:php}

5.内容页的调用方法:与第3点一样,但需要注意,默认是调用该文档上级的栏目id,即点击后跳转到上一级栏目进行筛选。如果有多级栏目,需要跳转到顶级栏目时,请增加一个参数,格式为:{dede:php} AddFilter(栏目id,显示类型,'字段名1,字段名2,字段名3……',栏目id,1); {/dede:php}

6.新增当前筛选参数输出功能,用于SEO。例如当前选择了“北京”,“北京”所在的参数组是“diqu”,则在模板上写标签{dede:field.diqu/}
即可输出“北京”到页面上。

注意事项
  1. 模型ID可以在核心 - 频道模型 - 内容模型管理 找到,该页面的id号即是模型ID;
  2. 前台调用时,不能嵌套于织梦标签之内。
  3. 如果前台调不出来,请到后台:系统 - 系统设置 - 系统基本参数 - 其他选项 - 禁用模板标签 ,把“php”删除后保存。

四、关于样式问题


因为前台模板千变万化,我们没有写css,写也也未必适合您的网站。在这里我们给出css方案,我们可以指定一个有ID的容器,然后在容器里调用筛选类别,那么我们就可以通过ID来定义css。

例:<div id="filter">{dede:php} AddFilter(1); {/dede:php}</div>,当未被选中时,文字外面的标签是<a></a>,选中后返回的标签是<span></span>,


这样我们就可以分别定义它们的样式了。css代码可以写在页头,或者写进模板目录的css文件,默认是在templets/default/style/这个目录,我们可以写在dedecms.css或page.css这两个文件其中一个,建议page.css。

例如我们要使选中后的选项文字为红色加粗体,则在page.css后面加上这样一段代码:#filter span{ color:#F00; font-weight:bold; },
我们也可以定义链接文字(非选中的选项)的样式,如文字颜色设成灰色、不要下划线:#filter a{ color:#CCC; text-underline:none; }。更多样式就需要您自由发挥了。

五,织梦复合筛选演示地址


依旧织梦网织梦模板:http://www.19dede.com/dedemuban/
 
插件下载

网盘下载

(提取密码:67y1  ,  解压密码:www.19dede.com)

上一篇:上一篇:没有了
下一篇:下一篇:没有了
发表评论:
特价模板
特价织梦模板本站将持续推出,特价模板不参与其他促销活动!