您好,欢迎来到菜鸟吧源码网-本站资源仅供学习与参考,禁止用于商业或违法行为!
  • 首 页
  • 下载APP
  • 公告:菜鸟吧APP于2024.9.15正式上线,请首页右上角进入下载,本站资源均来源于互联网及会员投稿发布,所有资源仅供学习参考研究使用,请勿商用或其它非法用途,商用请购买正版,否则产生一切后果由用户自行承担!谢谢!

     

    当前位置:主页 > 站长学堂 > dede教程 >
    dede问答平台开发笔记
    时间:2020-03-01 11:47 作者:菜鸟哥 浏览:收藏 挑错 打印

    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  }} ?>

    就讲到这里吧

    郑重声明:
    本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,不存在任何商业目的与商业用途。 若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
    我们不承担任何技术及版权问题,且不对任何资源负法律责任。
    如无法下载,联系站长索要。
    如有侵犯您的版权,请给我们来信:cainiaovip8@qq.com,我们尽快处理。

    织梦中TAG标签字数长度限制解决方法织梦中TAG标签字数长度限制解决方法
    织梦后台突然打不开或打开后空白的解决方法织梦后台突然打不开或打开后空白的解决
    织梦系统解决后台“DEDECMS安全提示”的方法织梦系统解决后台“DEDECMS安全提示”