Thinkphp关联模型使用

Posted Cabinet

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Thinkphp关联模型使用相关的知识,希望对你有一定的参考价值。

1.需求描述

首页文章列表,需要同时获取文章的点赞和被关注数,同时如果被当前用户点赞或关注了会显示相应小图标进行区别。图示如下:

2.解决方案

数据库设计:

文章对应Article表,其中包括收藏数字段fav,点赞数字段zan

中间表user_fav,user_zan分别表示某一用户对某篇文章的点赞与收藏, 其中包括userid,usertype,article_id等字段

TP5代码实现部分:

框架用的TP5,参考开发手册其中关联模型部分,在article模型中增加userFav和userZan方法

    public function userFav()
    {
        return $this->hasMany(\'UserFav\',\'article_id\')->field(\'userid\');
    }

    public function userZan()
    {
        return $this->hasMany(\'UserZan\',\'article_id\')->field(\'userid\');
    }

Controller中index方法显示文章列表

    public function index($page=1)
    {
        // $this->articlemodel = new Article();
        // $list = $this->articlemodel->where(\'schoolid\',$user[\'schoolid\'])->where(\'classid\',$user[\'classid\'])->group(\'create_time\')->select();
        $list = $this->articlemodel->withCount([\'userzan\'=>function($query){
            $query->where(\'userid\',cookie(\'userid\'))->where(\'usertype\',cookie(\'usertype\'));
        }])->order(\'zan desc,is_top desc,is_recommend desc,id desc\')->paginate(5,false,[\'page\' => $page]);
        
        $this->assign(\'list\', $list);        
        return $this->fetch();
    }

View中获取点赞数关注数同时判断如果当前用户点赞,部分代码

    {volist name="list" id="vo"}
    <div class="in_parent">
        <img src="{$vo[\'photo\'][0]}" data-id="{$vo[\'id\']}">
        <div class="in_par_con">
            <p>{$vo.title}</p>
        </div>
        <div class="in_par_con">
          {foreach :explode(\',\',$vo[\'tags\']) as $tag}
            <span>{$tag}</span>
            {/foreach}
        </div>
        <div class="in_per">
            <div class="in_per_lf fl">
                <img src="__H5IMAGES__/pic.png" class="fl"/>
                <div class="fl ml5 mt10">{$vo.author}<p class="gray">{php}echo date(\'Y-m-d\',strtotime($vo[\'create_time\']));{/php}</p></div>
            </div>
            <div class="in_per_rt fr">
                <span class="gray fr mt30 ml3 care-val">收藏 {$vo.fav}</span>
                <div class="fr mt30 ml3 care{eq name=\'$vo.userfav_count\' value=\'1\'} care01{/eq}" data-id="{$vo.id}"></div>
                <span class="gray fr mt30 ml3 zan-val">{$vo.zan}</span>
                <div class="fr mt30 ml3 zan{eq name=\'$vo.userzan_count\' value=\'1\'} zan01{/eq}" data-id="{$vo.id}"></div>
            </div>
            <div class="clear"></div>
        </div>
    </div>
    {/volist}

 

php用的时间不长,用的不对的地方望不吝赐教

以上是关于Thinkphp关联模型使用的主要内容,如果未能解决你的问题,请参考以下文章

10 关联模型《ThinkPHP6 入门到电商实战》

10 关联模型《ThinkPHP6 入门到电商实战》

ThinkPHP 3.2.3 关联模型的使用

ThinkPHP - 关联模型

thinkphp利用模型关联来做关联统计

使用thinkphp 关联模型has_one插入数据问题:插入数据的时候只操作一张表为啥?