DEDECMS 5.6分类信息过滤的实践

最近帮朋友做了一个物流系统的二次开发,主要还是模板设计。其实有一个应用方案:我们有一个新建的频道模型,其中有个字段是用的dede中的地区联动表单——nativeplace。现在如果客户进来以后会发现有大量的信息,而客户最关心的还是自己身边的目标信息。因此

最近帮朋友做了一个物流系统的二次开发,主要还是模板设计。其实有一个应用方案:我们有一个新建的频道模型,其中有个字段是用的dede中的地区联动表单——nativeplace。现在如果客户进来以后会发现有大量的信息,而客户最关心的还是自己身边的目标信息。因此就希望能通过地区选择对此分类信息进行过滤。

效果如上图所示,下面献上相关代码。首先在对应的List模板中添加以下内容,作用是生成图中顶上的过滤选项:
{dede:infoguide}
    <form name='infoguide' method='get' action='/plus/list.php'>
 <table>
  <tr>
   <td> [field:nativeplace /]</td>
   <td> [field:infotype /]</td>
   <td> <span class='infosearchtxt'>关键字:</span>
   <span><input type='text' name='keyword' value='' class="ipt-txt" /></span>
            <input type='submit' value='搜索信息' class="btn-2" style='cursor:pointer' /></td>
   <td><input type='button' value='发布信息' class="btn-2"
            onclick="location='/member/archives_sg_add.php?channelid=-8';" style='cursor:pointer' /></td>
   </tr>
   </table>
   <input type='hidden' name='tid' value='[field:typeid /]' />
        <input type='hidden' name='channelid' value='-8' />
 </form>
{/dede:infoguide}

  下面我只讲地区过滤的实现,其它的请自己补充。找到/plus/list.php中:$t1 = ExecTime();改为以上代码
___FCKpd___1
  这里关键是定义了一个$mysql变量,胜于组织过滤的SQL语句。
  还是这个文件,接着往下找$lv = new ListView($tid);改为:$lv = new ListView($tid,$mySql);。
  找到include/arc.listview.class.php在:var $remoteDir;后面添加:var $mySql;
  将下面的//php5构造函数改为:function __construct($typeid,$mySql,$uppage=1);
  接着将在:global $dsql,$ftp;后面添加一行:$this->mySql = $mySql;
  接下来在这个文件中有一段官方注释://普通情况先从arctiny表查出ID,然后按ID查询(速度非常快)找到此处。下面有两个else,我们要改的地方是第二个else中的query 。也就是整个文件中的第一个$t2 = ExecTime();之前的那个else中的Query.将其where后面的部分改为:where arc.id in($idstr) $mySql $ordersql “;
  至此,我们的分类信息过滤就已经可以用了。
 

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

关于面包屑导航栏目链接相对路径的修改方法 好吧,自己解决了,现在写出来,希望可以帮到有同样问题的人。 找到/include/typelink.class.php 然后找到下面代码,大概在196行的位置 function GetOneTypeLink($typeinfos) { $typepage = $this-GetOneTypeUrl($
织梦后台默认生成更新RSS文件是按照网站栏目生成告诉用户每个栏目的RSS订阅地址,保存在data目录下,按分类生成很适合栏目或栏目文章较多的dedecms站点,小型CMS站点偏向于生成一个全站的RSS 文件,下面的方法可以实现dedecms只生成一个rss.xml文件夹保存于
有时候,我们在用dedecms建网站的时候,在图片集内容页需要调用当前文章的所有图片出来,这个时候就需要在内容页吧网站里面的所有图片都调用出来了,该怎么做呢?下面看具体步骤: 第一步: 打开include/extend.func.php,在后面加入以下代码 复制代码 functi
dedecms获得某篇文章内容的几种方法,在这里给大家总结了以下三种方法: 1. 使用SQL {dede:sql sql=Select body from `dede_addonarticle` where aid=146} [field:body/] {/dede:sql} 2.使用arclist, 用idlist获取,aid 是没用的,在首页记得要获取typeid,
本文实例讲述了dedecms删除系统自定义变量的方法。分享给大家供大家参考。具体实现方法如下: 一、问题: 之前添加了个联系电话的系统变量,选错了变量类型,结果电话里面要是出现-就显示不全了,很难看,这样的就要删除了重来,那么织梦怎么删除添加的变量呢。
简略标题调用标签: 独立使用标签,如:内容页、title {dede:field.shorttitle/} 嵌套使用标签,如:{dede:arclist}{dede:list} [field:shorttitle/] 当有简略标题时显示简略标题,没有简略标题时显示正标题: {dede:field name=array runphp=yes} if(@me[sho