• 微软原版系统

  • 一键重装系统

  • 纯净系统

  • 在线技术客服

魔法猪系统重装大师 一键在线制作启动 U 盘 PE 系统 用一键重装的魔法拯救失去灵魂的系统
当前位置:首页 > 教程 > 电脑教程

DEDECMSv5.6教程之实现分类信息的过滤

时间:2015年04月02日 15:40:36    来源:魔法猪系统重装大师官网    人气:17283

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

\

效果如上图所示,下面献上相关代码。首先在对应的List模板中添加以下内容,作用是生成图中顶上的过滤选项:

{dede:infoguide}

[field:nativeplace /] [field:infotype /] 关键字:
{/dede:infoguide}

  下面我只讲地区过滤的实现,其它的请自己补充。找到/plus/list.php中:$t1 = ExecTime();改为以上代码

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

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

DEDECMSv5.6,教程,之,实现,分,类信息,的,过滤
栏目:电脑教程 阅读:1000 2023/12/27
Win7教程 更多>>
U盘教程 更多>>
Win10教程 更多>>
魔法猪学院 更多>>

Copyright © 2015-2023 魔法猪 魔法猪系统重装大师

本站发布的系统仅为个人学习测试使用,请在下载后24小时内删除,不得用于任何商业用途,否则后果自负,请支持购买微软正版软件。

在线客服 查看微信 返回顶部