设为首页 加入收藏

TOP

DEDECMS v5.6中分类信息过滤的实现
2011-08-21 04:33:11 来源: 作者: 【 】 浏览:513次 评论:0
DEDECMS v5.6中分类信息过滤的实现 - CMS教程 - 烈火网

DEDECMS v5.6中分类信息过滤的实现

本教程展示如何在dede5.6中如何实现信息过滤,前提是你用的是使用动态页即可。转载请保留此链接:关于DEDE5.6中分类信息过滤的实践。

这些天在做一个物流系统的二次开发,主要还是模板设计。下面先介绍这个应用背景:我们有一个新建的频道模型,其中有个字段是用的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();改为以上代码

$t1 = ExecTime();$mySql;foreach(

本教程展示如何在dede5.6中如何实现信息过滤,前提是你用的是使用动态页即可。转载请保留此链接:关于DEDE5.6中分类信息过滤的实践。

这些天在做一个物流系统的二次开发,主要还是模板设计。下面先介绍这个应用背景:我们有一个新建的频道模型,其中有个字段是用的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 “;

  至此,我们的分类信息过滤就已经可以用了。

GET as $k => $v){ if($k=='nativeplace'){ $mySql = $mySql . ' and ' . $k . "='" . $v . "'"; }}

  这里关键是定义了一个$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 “;

  至此,我们的分类信息过滤就已经可以用了。

    90.9% (10)
    9.1% (1)
    Tag标签:DEDECMS 分类信息 
    本文编辑:柳絮随风
    更多..

    网友评论

    发表评论(拉取统计信息……)
    用户名: 验证码:点击更换

     

    超过 人围观,
    您看到此篇文章时的感受是:
    Tags: 责任编辑:administrator
    】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
    分享到QQ空间
    分享到: 
    上一篇PHPCMS内容页实现点击图片进入下.. 下一篇DEDECMS限时优惠价购买实时倒计时

    评论

    帐  号: 密码: (新用户注册)
    验 证 码:
    表  情:
    内  容:

    相关栏目

    最新文章

    图片主题

    热门文章

    推荐文章

    相关文章

    广告位