【thinkphp5】【THINKCMG】标签部分开发(一)

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sinat_21158419/article/details/52714203 ...
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/sinat_21158419/article/details/52714203

最近打算开一个自己的CMS后台轮子,框架选择了thinkphp 5 (别问我为什么选择这个框架)然后想边开发边记录一下,方便自己方便他人

进入正题

1.数据库设计

一共三张表

post文章表这个就不贴了(在这里没有使用到)

主要是以下两张


一张是存储标签的tag表,

另一张是关系表用于关联标签与文章


2.代码部分

主要我们使用到了thinkphp5的多对多关联(想详细了解的可以看这里 多对多关联


文章表对应的模型

model/Posts.php

<?php

namespace app\admin\model;

use think\Model;

class Posts extends Model
{
    protected function initialize()
    {
        parent::initialize();
    }
    public function tag()
    {
        return $this->belongsToMany('Tags', 'tag_relationships');
    }
}
主要是tag这个函数通过belangsTomany把文章表与标签和关系表做个关联

因为我们还要做到标签找到相关文章我们还得给标签模型加个关联


标签表对应模型

model/Tags.php

<?php

namespace app\admin\model;

use think\Model;

class Tags extends Model
{
    protected function initialize()
    {
        parent::initialize();
    }
    public function post()
    {
        return $this->belongsToMany('Posts', 'tag_relationships');
    }

}
一样的道理不在叙述


下面开始控制器部分

先写新发表文章的标签部分

controller/Post.php

public function doadd(Request $request)
    {
<span style="white-space:pre">	</span>//文章部分不再贴出,但需要先进行写入然后返回文章uid
        $result = $request->param();
        $re_tags = explode(',', $result['tags']);
        //  标签写入
        for ($i=0; $i <count($re_tags); $i++) {
            $data[]=['name'=>$re_tags[$i]];
        }
        $post = PostAdminModel::get($uid);
        $post->tag()->saveAll($data);
    }
说明

$result //post数组

$uid //文章储存完后返回来的主键uid


因为前端标签插件发送的数据格式是通过逗号分隔,所以我们接收到数据后转换为['key'=>'value'](在代码中name是我标签表中标签名字对应的键值名)方便接下来的操作

接下来就是通过Post模型静态调用get方法(默认输入为主键)

然后通过批量增加关联数据操作把刚才我们组合的标签数组传进来

这样新增就完成了


接下来我们开始写编辑页的标签操作

在这里我们先分析一下我们的标签可能的操作

1.删除标签但不删除标签库中的

2.新增标签但是不存在于标签表中

3.新增标签但是存在于标签表中

4.取出全部标签

    public function edit($uid)
    {
        if (Request::instance()->isPost()) {
            $request = Request::instance();
            $result = $request->param();
            //标签 Start
            $re_tags = $result['tags'];
            $taglist = explode(',',$re_tags);
            $post = PostAdminModel::get($uid);
            foreach($post->tag as $value)
            {
                $orglist[] = $value['name'];
            }
            //删除标签    <pre name="code" class="php">             //文章的关联标签与前端传递过来的标签进行对比(顺序不能错了)如果存在值则进行删除操作
            $dellist=array_diff($orglist,$taglist);
            if($dellist)
            {
                foreach($dellist as $value)
                //删除关联操作
                $tag  = TagsAdminModel::getByName($value);
                $post->tag()->detach($tag);
            }
            //增加标签
             //与之前的比较相反即增加操作
            $addlist=array_diff($taglist,$orglist);
            if($addlist)
            {
                foreach($addlist as $value)
                {
<span style="white-space:pre">		</span>   //标签存在于标签库中则只增加关联,不存在则新增
                    $tagresult= TagsAdminModel::getByName($value);
                    if($tagresult)
                    {
                        $tagid = $tagresult->value('id');
                        $post->tag()->attach($tagid);

                    }else{
                        $post->tag()->save(['name'=>$value]);
                    }
                }
            }
            //标签 End
            }
        }
        //渲染获取文章数据
        //因为我们进行了关联所以可以直接通过查询文章表并获取到标签集
        $request=PostAdminModel::get($uid);
        $tags="";
        for ($i=0; $i <count($request->tag); $i++) {
            $tags .= $request->tag[$i]['name'].',';
        }
        $this->assign('tags', $tags);
        return $this->fetch();
    }


 
 

改说的都写在注释里了


其实关于后台的标签操作还有就是单独对于标签的操作

这个就相对简单了直接操作标签的增加删除修改即可

但是在删除的时候一定要注意先进行关联删除再进行标签的删除


前端显示就是文章本身的标签显示这个也简单

还有就是标签反查文章基本方法我在上面都写了

可以按照需求进行修改即可

不出意外我后续还会续上


写的可能很啰嗦很乱 大家凑活看吧~

有问题可以留言问










目录
相关文章
|
Web App开发 数据安全/隐私保护 网络协议
|
Linux 网络安全 数据安全/隐私保护
Linux 使用ssh密钥认证方式登陆另一台linux服务器
Linux 使用ssh密钥认证方式登陆另一台linux服务器
力扣200:岛屿数量(Java dfs+bfs)
给你一个由 '1'(陆地)和 '0'(水)组成的的二维网格,请你计算网格中岛屿的数量。 岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。
231 0
|
2天前
|
存储 弹性计算 人工智能
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
2025年9月24日,阿里云弹性计算团队多位产品、技术专家及服务器团队技术专家共同在【2025云栖大会】现场带来了《通用计算产品发布与行业实践》的专场论坛,本论坛聚焦弹性计算多款通用算力产品发布。同时,ECS云服务器安全能力、资源售卖模式、计算AI助手等用户体验关键环节也宣布升级,让用云更简单、更智能。海尔三翼鸟云服务负责人刘建锋先生作为特邀嘉宾,莅临现场分享了关于阿里云ECS g9i推动AIoT平台的场景落地实践。
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
|
4天前
|
云安全 数据采集 人工智能
古茗联名引爆全网,阿里云三层防护助力对抗黑产
阿里云三层校验+风险识别,为古茗每一杯奶茶保驾护航!
古茗联名引爆全网,阿里云三层防护助力对抗黑产
|
4天前
|
存储 机器学习/深度学习 人工智能
大模型微调技术:LoRA原理与实践
本文深入解析大语言模型微调中的关键技术——低秩自适应(LoRA)。通过分析全参数微调的计算瓶颈,详细阐述LoRA的数学原理、实现机制和优势特点。文章包含完整的PyTorch实现代码、性能对比实验以及实际应用场景,为开发者提供高效微调大模型的实践指南。
534 2
kde
|
4天前
|
人工智能 关系型数据库 PostgreSQL
n8n Docker 部署手册
n8n是一款开源工作流自动化平台,支持低代码与可编程模式,集成400+服务节点,原生支持AI与API连接,可自托管部署,助力团队构建安全高效的自动化流程。
kde
362 3