zoukankan      html  css  js  c++  java
  • TP5.0实现无限极回复功能

    最近做项目的时候用到了评论回复,使用ThinkPHP5.0框架做回复碰到了一些问题,简单总结一下。(李昌辉)

    1.首先是数据表的设计:

    create table zy_huifu
    (
    	code int auto_increment primary key, #回复代号
    	puser varchar(50), #回复人员
    	listcode int, #文章代号
    	time varchar(50), #回复时间
    	content text, #回复内容
    	pcode int, #父级代号 0文章
    	leval int, #级别 0顶级 1其它
    	isok int #已读未读0未读1已读
    );
    

    评论和回复放在了一张表里面,为了在显示的时候做区分,评论作为顶级回复级别代号为0,其它的子级回复级别代号为1。

    每个回复都有一个父级代号代表回复的哪一条评论,如果是直接评论的文章,父级代号设置为0.

    2.接下来是在页面上显示评论和回复信息:

     在控制器里面,我们需要去查询该文章下的所有评论及回复内容,并且注册到TP框架里面,这里调用了一个方法CommentList()来获取该文章下的评论回复:

    //查询评论
    $ahuifu = $this->CommentList($code,0);
    $this->assign("ahuifu",$ahuifu);
    

    CommentList()方法如下,使用递归的方式将所有评论回复按照一定的顺序查询出来并且存储到数组里面:

    //读取评论列表的递归,code为文章代号,pcode为父级代号
        public function CommentList($code,$pcode){
            $commentlist = array(); //存储评论数组
            $list = Db::table("zy_huifu")
            ->alias('a')
            ->where("listcode",$code)
            ->where("pcode",$pcode)
            ->join("zy_user b","a.puser = b.uid")
            ->select();
            
            foreach($list as $v){
                $commentlist[] = $v;
                //查询子回复
                $zi = $this->CommentList($code,$v["code"]);
                if(count($zi)){
                    foreach($zi as $v1){
                        $commentlist[] = $v1;
                    }
                }
            }
            return $commentlist;
        }

    在view视图页面显示数据:

    {volist name="ahuifu" id="vp"}
                    {if condition="($vp.leval == 0)"} 
                    <div class="panel panel-default pl_list">
                    <div class="panel-body pl_list_nr">
                        <div class="show_nr_pl_tou">
                            <img src="{$vp.img}" width="30" height="30" /> &nbsp;
                            <span>{$vp.name}</span>&nbsp;
                            <span>{$vp.time|date="Y-m-d H:i:s",###}</span>&nbsp;
                            <span><button class="btn btn-primary btn-xs show_huifu_btn" pcode="{$vp.code}">回复</button></span>
                        </div>
                        <div class="show_nr_pl_nr">
                            {$vp.content}
                        </div>
                    </div>
                    </div>
                    {else /} 
                    <div class="panel panel-default pl_list">
                    <div class="panel-body pl_list_nr" style="margin-left:50px">
                        <div class="show_nr_pl_tou">
                            <img src="{$vp.img}" width="30" height="30" /> &nbsp;
                            <span>{$vp.name}</span>&nbsp;
                            <span>{$vp.time|date="Y-m-d H:i:s",###}</span>&nbsp;
                            <span><button class="btn btn-primary btn-xs show_huifu_btn" pcode="{$vp.code}">回复</button></span>
                        </div>
                        <div class="show_nr_pl_nr">
                            {$vp.content}
                        </div>
                    </div>
                    </div>
                    {/if}
                
    {/volist}

    3.添加回复及评论

    添加评论的时候注意将父级代号pcode添加为0,将级别leval添加为0即可。

    添加回复的时候将父级代号添加为要回复的这一条数据的主键,将级别leval添加为1即可。

    具体实现比较简单,不赘述。

  • 相关阅读:
    织梦DEDECMS更换目录后需要修改的内容绝对路径与相对路径问题
    <dedecms开发》给dede自定义表单添加提交验证功能
    PLSQL存储过程中的内部存储过程
    在Oracle中查询存储过程和函数
    PLSQL存储过程调用存储过程对异常的处理问题
    带参数存储过程的小例子
    对PLSQL的SQL%NOTFOUND的再验证
    PLSQL restrict reference的做法
    PLSQL的 dynamic sql小例子
    PLSQL execute immediate
  • 原文地址:https://www.cnblogs.com/lingxin/p/7500501.html
Copyright © 2011-2022 走看看