广

织梦CMS教程

  • 帝国cms教程
  • 织梦CMS教程
  • PHP CMS教程
  • ECSHOP教程
  • WordPress教程
  • Discuz教程
  • CMS学习

    DEDECMS问答模块添加在首页显示所有问题的方法

    2018-04-02 20:50:35 次阅读 稿源:互联网
    零七广告

    给问答模块添加在首页显示所有问题的功能(默认是没有的),很容易找到了ask/control/index.php文件,下面我将关键代码贴出来   

    1. //待解决的问题 
    2. $notoks = $this->question->get_all('status=0','ORDER BY disorder DESC, dateline DESC',$row); 
    3. //新解决的问题 
    4. $solutions = $this->question->get_all('status=1','ORDER BY solvetime DESC',$row); 
    5. //高分悬赏问题 
    6. $rewards = $this->question->get_all('status=0','ORDER BY reward DESC',$row); 

    看到了吧,这里就是查询不同条件下问题的列表,get_all()函数里面的参数是设置查找问题的条件status=1表示已解决问题,status=0表示未解决问题,如果我不要任何条件将这里设置成空 是不是就可以得到所有问题了呢,于是我将代码改成:

    1. //待解决的问题 
    2. $notoks = $this->question->get_all('status=0','ORDER BY disorder DESC, dateline DESC',$row); 
    3. //所有问题 
    4. $allqus = $this->question->get_all('','ORDER BY disorder DESC, dateline DESC',$row);  
    5. //新解决的问题 
    6. $solutions = $this->question->get_all('status=1','ORDER BY solvetime DESC',$row); 
    7. //高分悬赏问题 
    8. $rewards = $this->question->get_all('status=0','ORDER BY reward DESC',$row); 

    实验证明我错了,问答模块的代码没我想的那么智能化,找了很久终于发现原因所在。原来在模型mquestion里面,get_all()不管条件有没有指,都给sql语句加了个where

    1. $query = "SELECT $field FROM `jcode_ask` WHERE $wheresql $orderby limit 0,$row"

    这里的$wheresql我设置成了空,结果导致sql语句不全了,所以出错。改成

    1. if($wheresql==''){ 
    2. $query = "SELECT $field FROM `jcode_ask`  $orderby limit 0,$row";} 
    3. else{ 
    4. $query = "SELECT $field FROM`jcode_ask` WHERE $wheresql $orderby limit 0,$row";} 

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

    1. <?php   
    2. if($allqus!= ""){ 
    3. foreach($allqus as $key => $v){ 
    4. ?>  
    5. 这里是html代码,添加你自己的代码 
    6. <?php  }} ?> 

    零七网部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与零七网进行文章共享合作。

    零七广告
    零七广告
    零七广告