|
织梦默认的列表页没有筛选功能,但有时候我们做产品列表页的时候,产品的字段比较多,很多人都需要用到筛选功能,这样可以让用户更方便的找到自己所需要的东西,实现这个联动筛选功能需要对织梦进行二次开发,下面就告诉大家如何对织梦进行二次开发实现这个很多人都需要的筛选功能,如下图所示:
首先需要说明的是这个功能需要在模板里面用到php标签,所以需要在后台模板引擎禁用标签里面解除这个标签的禁用,具体方法:
后台——系统——系统基本参数——其它选项——模板引擎禁用标签:php
将这个PHP去掉后保存就可以了!
好了,下面开始正题了。
一、联动筛选单选功能
首先需要修改2个PHP文件,都是include目录下面的。
1、修改arc.listview.class.php文件,这文件改动比较大,建议大家直接下载附件压缩包里面的文件替换,如果你之前对这个文件改动过的话,请在下载下来的压缩包里的这个文件里面搜索有“织梦技术研究中心”这些注释的这些地方,都是修改过的,然自己手动将有注释的代码插入到自己的文件里面!
2、修改extend.func.php文件,在其最后面添加如下代码:
- //dedecms联动筛选功能 By 织梦技术研究中心 技术支持群:78494131字符过滤函数
- 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;
- }
-
- /**
- * 载入自定义表单(用于发布)
- *
- * @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 .= '<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>').' ';
-
- $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>')." ";
- }
- $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;
- }
复制代码
特别注意:代码复制后需要自己手动去掉上面代码中的两处【分隔符】。
下面提供前面提到过的已经修改好的文件下载,注意这个是对默认没有修改过的文件进行修改的,如果你已经对这两个文件进行过修改,那就请看这两个文件的注释部分相应的进行修改,下载地址:
http://pan.baidu.com/s/1hqs2E9Y
好,到这里PHP文件修改的部分就完成了!接下来就需要给指定的模型添加字段了,这里需要注意的就是 字段类型的选择,字段类型需要选择单选按钮或者使用select下拉框,如下图所示:
下面就是列表页模板筛选标签的调用了,筛选标签的调用很简单,一句代码就可以搞定,标签代码如下:
- {dede:php}AddFilter(4,1,'linestyle,linethem,youdays,jgqujian');{/dede:php}
复制代码
标签解释:
AddFilter函数里面的第一个数字4是内容模型的id号,各个内容模型的id请到后台内容模型管理里面查看;
第二个数字1是表示筛选的样式,1是使用超链接进行选择,2是使用select下拉框选择,具体可以自己设置了查看效果;
第三个部分'linestyle,linethem,youdays,jgqujian'是要添加筛选功能的字段名,这里有4个字段,注意需要用半角逗号隔开。
到这里联动筛选单选的功能就弄完了,如果只需要单选功能的朋友可以直接用了,但是如果需要多选功能的朋友请继续往下面看。
二、联动筛选多选功能
搜索情况类似下图:每个自定义字段值能选择N个值(url不能超过255个字符)
然后打开之前修改过的arc.listview.class.php文件,分别在第117行左右和第809行的左右的样子,找到如下代码:
1
$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显示的是中文,就可以直接使用上面的代码,否则的话在转码那可能要稍微修改下。
|
|