dede问答平台开发笔记
dedecms有个问答平台的模块,安装该模块之后会在根目录下面生成一个ask的目录,相关的代码和模板都在里面了,当然安装过程中还在数据库中添加了和问答相关的数据。
其实模块是和系统其它部分比较独立的程序集合,我发现这个问答模块的代码结构和dede其它地方的代码结构差别比较大,可能是程序员不同吧,问答模块基本上是基于mvc设计模式的,至少代码看上去和很多mvc框架相似,而且在问答模块里面,采用的模板也不再是dede文章模板的标签调用形式,问答模块里面可以很随意的嵌套php语句。尽管有些地方也能看到dede标签,但是我初步感觉,这个模板已经不再是dede的模板了,从后台和前台分离的角度来说,这不是好事,但是就个人来说我喜欢能使用php代码的模板。
好了今天我想给问答平台添加一个在首页显示所有问题的功能(默认是没有的),很容易找到了ask/control/index.php文件,下面我将关键代码贴出来:
//待解决的问题
$notoks = $this->question->get_all('status=0','ORDER BY disorder DESC, dateline DESC',$row);
//新解决的问题
$solutions = $this->question->get_all('status=1','ORDER BY solvetime DESC',$row);
//高分悬赏问题
$rewards = $this->question->get_all('status=0','ORDER BY reward DESC',$row);
看到了吧,这里就是查询不同条件下问题的列表,get_all()函数里面的参数是设置查找问题的条件status=1表示已解决问题,status=0表示未解决问题,如果我不要任何条件将这里设置成空 是不是就可以得到所有问题了呢,于是我将代码改成:
//待解决的问题
$notoks = $this->question->get_all('status=0','ORDER BY disorder DESC, dateline DESC',$row);
//所有问题
$allqus = $this->question->get_all('','ORDER BY disorder DESC, dateline DESC',$row);
//新解决的问题
$solutions = $this->question->get_all('status=1','ORDER BY solvetime DESC',$row);
//高分悬赏问题
$rewards = $this->question->get_all('status=0','ORDER BY reward DESC',$row);
实验证明我错了,问答模块的代码没我想的那么智能化,找了很久终于发现原因所在。原来在模型mquestion里面,get_all()不管条件有没有指,都给sql语句加了个where,
$query = "SELECT $field FROM `dede_ask` WHERE $wheresql $orderby limit 0,$row";
这里的$wheresql我设置成了空,结果导致sql语句不全了,所以出错。改成
if($wheresql=='')
$query = "SELECT $field FROM `dede_ask` $orderby limit 0,$row";
else
$query = "SELECT $field FROM`dede_ask` WHERE $wheresql $orderby limit 0,$row";
现在就可以了,后台代码已经改完,现在改前台。
增加
<?php
if($allqus!= ""){
foreach($allqus as $key => $v){
?>
这里是html代码,参照待解决问题
<?php }} ?>
就讲到这里吧
其实模块是和系统其它部分比较独立的程序集合,我发现这个问答模块的代码结构和dede其它地方的代码结构差别比较大,可能是程序员不同吧,问答模块基本上是基于mvc设计模式的,至少代码看上去和很多mvc框架相似,而且在问答模块里面,采用的模板也不再是dede文章模板的标签调用形式,问答模块里面可以很随意的嵌套php语句。尽管有些地方也能看到dede标签,但是我初步感觉,这个模板已经不再是dede的模板了,从后台和前台分离的角度来说,这不是好事,但是就个人来说我喜欢能使用php代码的模板。
好了今天我想给问答平台添加一个在首页显示所有问题的功能(默认是没有的),很容易找到了ask/control/index.php文件,下面我将关键代码贴出来:
//待解决的问题
$notoks = $this->question->get_all('status=0','ORDER BY disorder DESC, dateline DESC',$row);
//新解决的问题
$solutions = $this->question->get_all('status=1','ORDER BY solvetime DESC',$row);
//高分悬赏问题
$rewards = $this->question->get_all('status=0','ORDER BY reward DESC',$row);
看到了吧,这里就是查询不同条件下问题的列表,get_all()函数里面的参数是设置查找问题的条件status=1表示已解决问题,status=0表示未解决问题,如果我不要任何条件将这里设置成空 是不是就可以得到所有问题了呢,于是我将代码改成:
//待解决的问题
$notoks = $this->question->get_all('status=0','ORDER BY disorder DESC, dateline DESC',$row);
//所有问题
$allqus = $this->question->get_all('','ORDER BY disorder DESC, dateline DESC',$row);
//新解决的问题
$solutions = $this->question->get_all('status=1','ORDER BY solvetime DESC',$row);
//高分悬赏问题
$rewards = $this->question->get_all('status=0','ORDER BY reward DESC',$row);
实验证明我错了,问答模块的代码没我想的那么智能化,找了很久终于发现原因所在。原来在模型mquestion里面,get_all()不管条件有没有指,都给sql语句加了个where,
$query = "SELECT $field FROM `dede_ask` WHERE $wheresql $orderby limit 0,$row";
这里的$wheresql我设置成了空,结果导致sql语句不全了,所以出错。改成
if($wheresql=='')
$query = "SELECT $field FROM `dede_ask` $orderby limit 0,$row";
else
$query = "SELECT $field FROM`dede_ask` WHERE $wheresql $orderby limit 0,$row";
现在就可以了,后台代码已经改完,现在改前台。
增加
<?php
if($allqus!= ""){
foreach($allqus as $key => $v){
?>
这里是html代码,参照待解决问题
<?php }} ?>
就讲到这里吧
免责声明:本站所有文章和图片均来自用户分享和网络收集,文章和图片版权归原作者及原出处所有,仅供学习与参考,请勿用于商业用途,如果损害了您的权利,请联系网站客服处理。
来源:网友投稿 关注:
时间:2018-03-21 09:12
☉首先声明,只要是我们的vip会员所有源码均可以免费下载,不做任何限制(了解更多)
☉本站的源码不会像其它下载站一样植入大量的广告。为了更好的用户体验以后坚持不打水印
☉本站只提供精品织梦源码,源码在于可用,不在多!!希望在这里找到你合适的。
☉本站提供的整站织梦程序,均带数据及演示地址。可以在任一源码详情页查看演示地址
☉本站所有资源(包括源码、模板、素材、特效等)仅供学习与参考,请勿用于商业用途。
☉如有其他问题,请加网站客服QQ进行交流。
☉本站的源码不会像其它下载站一样植入大量的广告。为了更好的用户体验以后坚持不打水印
☉本站只提供精品织梦源码,源码在于可用,不在多!!希望在这里找到你合适的。
☉本站提供的整站织梦程序,均带数据及演示地址。可以在任一源码详情页查看演示地址
☉本站所有资源(包括源码、模板、素材、特效等)仅供学习与参考,请勿用于商业用途。
☉如有其他问题,请加网站客服QQ进行交流。
相关织梦教程:
- 最好最实用的二次开发教程(dedeCMS,ecshop为例)
- Dede二次开发程序详解(dede学习必备一)
- dedecms制作Html+Css代码运行框jQuery版
- 织梦CMS二次开发列表AJAX按条件排序
- 织梦CMS二次开发不同栏目调用不同的模板教程
- dedecms 实现友情链接在首页、内页分别显示
- 如何加快dedecms 内容生成速度方法
- 如何使用DEDEcms/织梦制作复合筛选或联动筛选图解
- DEDECMS批量导入excel数据到后台文章系统的开发教程
- DEDECMS JSON数据生成 DEDECMS JSON接口制作
- 织梦DedeCMS禁止调用隐藏栏目下文章的开发方法
- dede地区联动搜索 彻底解决办法
常用程序开发
- 织梦Dedecms的channelartlist标签支持当前栏目高亮方
- DEDE5.6,DEDE5.7实现同时调用一级、二级、三级栏目
- 如何使用DEDEcms/织梦制作复合筛选或联动筛选图解
- dedecms 调用指定栏目,指定作者,指定自定义字段
- 织梦dedecms5.7标签tags静态化生成HTML方法
- dedecms 自定义表单分页+模版显示
- dedecms 二次开发调用当前作者文档的标签
- 织梦arclist标签实现分页的方法
- 织梦首页列表实现分页的两种方法
- DEDECMS会员空间调用收藏
- 在文章页直接调用dede织梦自定义字段图片地址
- 织梦dedecms首页列表页ajax点击下拉加载更多文章瀑布