• 全国400电话网上服务平台
    强大号码库资源任选,方便,快捷,快速开通。
    咨询热线:400-1100-266  

    dede问答平台开发笔记
    POST TIME:2021-05-24 03:10
    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  }} ?>

    就讲到这里吧
    
    关于我们 | 付款方式 | 建站知识 | 增值服务 | 网站模板
    Copyright © 2003-2016
    时间:9:00-21:00 (节假日不休)
    版权所有:巨人网络(扬州)科技有限公司
    总部地址:江苏省信息产业基地11号楼四层
    《增值电信业务经营许可证》 苏B2-20120278
    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信

    微信号已复制,请打开微信添加咨询详情!