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 FROMdede_ask WHERE $wheresql $orderby limit 0,$row";

现在就可以了,后台代码已经改完,现在改前台。



增加

<?php



if($allqus!= ""){

foreach($allqus as $key => $v){

?>

这里是html代码,参照待解决问题



<?php}}?>



就讲到这里吧

版权免责声明

① 本站VIP源码资源永久免费下载 www.wayu.cn
② 本网站资源来源于网络收集,如有侵权,请联系站长进行删除处理。
③ 分享目的仅供大家学习和交流,请不要用于商业用途,否则后果自负。
④ 如果你有源码需要出售,可以联系小编,或者点击 投稿
⑤ 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解。
⑥ 本站资源售价只是赞助,收取费用仅维持本站的日常运营所需。
⑦ 在您的能力范围内,为了大环境的良性发展,请尽可能的选择正版资源。
⑧ 网站资源不做任何二次加密和授权后门(原版加密除外)

评论0

请先

源码安装后,如有要求加QQ获取帮助的,请放弃使用,小心被骗。

没有账号? 忘记密码?