【20-业务开发-基础业务-商品模块-分类管理-前端展示后端具有层级关系的目录数据-商品系统三级分类的逻辑删除前后端代码实现】

news2025/1/17 2:49:11

一.知识回顾

【0.三高商城系统的专题专栏都帮你整理好了,请点击这里!】
【1-系统架构演进过程】
【2-微服务系统架构需求】
【3-高性能、高并发、高可用的三高商城系统项目介绍】
【4-Linux云服务器上安装Docker】
【5-Docker安装部署MySQL和Redis服务】
【6-Git安装与配置过程、Gitee码云上创建项目、IDEA关联克隆的项目】
【7-创建商城系统的子模块并将修改后的信息使用Git提交到Gitee上】
【8-数据库表结构的创建&后台管理系统的搭建】
【9-前端项目的搭建部署、Node安装、VSCode安装】
【10-Node的安装以及全局环境变量的相关配置&解决启动报错的问题(1.Error: Cannot find module ‘fs/promises)(2.npm安装node-sass报错)】
【11-导入人人generator项目并自动生成相关的文件&商品子模块的调试&公共模块common子模块的抽离与实现&Lombok插件的安装】
【12-商品子模块整合MyBatisPlus技术&其它模块通过generator的自动生成与补充完善】
【13-项目中微服务组件的学习-SpringCloudAlibaba微服务生态体系的学习&SpringCloudAlibaba的依赖管理&项目中SpringBoot和SpringCloud版本的统一】
【14-微服务的注册中心与配置中心Nacos&Windows操作系统上安装Nacos和Linux操作系统上用Docker中安装Nacos&每个子项目模块使用Nacos进行服务注册与发现】
【15-项目中服务的远程调用之OpenFeign&订单模块与商品模块集成使用OpenFeign的案例】
【16-配置中心之Nacos的基本使用&Nacos服务之命令空间、Nacos服务之配置组、Nacos服务之配置拆分】
【17-微服务网关之Spring Cloud Gateway&Spring Cloud Gateway网关服务搭建】
【18-业务开发-基础业务-商品模块-分类管理-前后端管理系统的启动-为分类管理表增加数据-Json插件的下载-返回具有层级目录、父子关系结构的数据】
【19-业务开发-基础业务-商品模块-分类管理-管理系统新建菜单-后端项目renren注册到Nacos注册中心和配置中心去-项目gateway网关模块的搭建-浏览器的同源策略与解决跨域问题实操案例】

二.前端展示后端具有层级关系的目录数据

首先需要在Gateway中配置商品服务的路由信息,同时要注意配置规则的先后顺序

在这里插入图片描述

然后服务端响应的数据的字段要在Vue文件中显示的对应,才能正确的显示

在这里插入图片描述

启动前端项目

npm run dev

启动后端项目:
依次启动后端管理模块–》网关模块–》商品模块

启动成功后先去nacos中查看服务是否注册成功
在这里插入图片描述

然后进行访问测试

在这里插入图片描述

三.商品系统三级分类的删除类别

3.1 删除类别的前端实现

product目录下category.vue中前端代码相关的实现

<template>
    <div>
      <el-tree :data="data" :props="defaultProps" 
        :expand-on-click-node="false"
        show-checkbox
        node-key="catId"
        >
        <span class="custom-tree-node" slot-scope="{ node, data }">
          <span>{{ node.label }}</span>
          <span>
            <el-button v-if="data.catLevel <= 2" type="text" size="mini" @click="() => append(data)">
              添加
            </el-button>
            <el-button v-if="data.childrens.length == 0" type="text" size="mini" @click="() => remove(node, data)">
              删除
            </el-button>
          </span>
        </span>
      </el-tree>
    </div>
</template>
  
<script>
/* eslint-disable */
    export default {
        data() {
            return {
            data: [],
            defaultProps: {
                children: "childrens",
                label: "name",
            },
            };
        },
        methods: {
            getCategory() {
            this.$http({
                url: this.$http.adornUrl("/product/category/listTree"),
                method: "get",
            }).then(({ data }) => {
                console.log("成功获取的类别数据:", data.data);
                this.data = data.data;
            });
            },append(data) {
                console.log("添加",data)
            },
            remove(node, data) {
                console.log("删除",data,node)
            }
        },
        created() {
            this.getCategory();
        },
    };
</script>

<style>
</style>

结果展示:
在这里插入图片描述

3.2 逻辑删除类别的后端实现

在实际开发中针对数据删除这块我们一般都会采用逻辑删除的方法来操作。在本项目中我们可以通过mybatis-Puls中提供的逻辑删除方式来实现。

Mybatis-plus的逻辑实现
官方指导方法:
在这里插入图片描述

具体实操:
首先配置全局的逻辑删除逻辑
在这里插入图片描述

然后在entity的字段中显示的标明:

在这里插入图片描述

controller层定义访问接口
在这里插入图片描述

service逻辑层实现相关的接口

在这里插入图片描述

然后我们就可以在service实现类中继续使用delete相关的方法来操作了

    /**
     * 逻辑批量删除操作
     * @param ids
     */
    @Override
    public void removeCategoryByIds(List<Long> ids) {
        // TODO  1.检查类别数据是否在其他业务中使用

        // 2.批量逻辑删除操作
        baseMapper.deleteBatchIds(ids);

    }

在这里插入图片描述
重新启动我们的mall-produce服务,并查看一下数据库最后第999和1000条数据状态,此时都是1,没有删除状态。
在这里插入图片描述

接下来通过postman测试

在这里插入图片描述

然后在数据库中反应的效果

在这里插入图片描述

3.3 前后端代码的串联实现

修改前端代码,首先需要通过ajax异步的来提交post请求到后端服务

<template>
    <div>
        <el-tree :data="data" :props="defaultProps" :expand-on-click-node="false"  show-checkbox node-key="catId" :default-expanded-keys=expandKeys>
            <span class="custom-tree-node" slot-scope="{ node, data }">
                <span>{{ node.label }}</span>
                <span>
                    <el-button v-if="data.catLevel <= 2" type="text" size="mini" @click="() => append(data)">
                        添加
                    </el-button>
                    <el-button v-if="data.childrens.length == 0" type="text" size="mini"
                        @click="() => remove(node, data)">
                        删除
                    </el-button>
                </span>
            </span>
        </el-tree>
    </div>
</template>
  
<script>
/* eslint-disable */
export default {
    data() {
        return {
            data: [],
            expandKeys:[],
            defaultProps: {
                children: "childrens",
                label: "name",
            },
        };
    },
    methods: {
        getCategory() {
            this.$http({
                url: this.$http.adornUrl("/product/category/listTree"),
                method: "get",
            }).then(({ data }) => {
                console.log("成功获取的类别数据:", data.data);
                this.data = data.data;
            });
        }, append(data) {
            console.log("添加", data)
        },
        remove(node, data) {
            this.$confirm(`是否确认删除【${data.name}】记录?`, "提示", {
                confirmButtonText: "确定",
                cancelButtonText: "取消",
                type: "warning",
            })
                .then(() => {
                    // 传递的数据
                    let ids = [data.catId];
                    // 把删除的请求提交到后台服务
                    this.$http({
                        url: this.$http.adornUrl("/product/category/delete"),
                        method: "post",
                        data: this.$http.adornData(ids, false),
                    }).then(({ data }) => {
                        if (data && data.code === 0) {
                            this.$message({
                                message: "操作成功",
                                type: "success",
                            });
                            // 重新加载所有的菜单数据
                            this.getCategory();
                            // 设置默认展开的父节点信息
                            this.expandKeys = [node.parent.data.catId]
                        } else {
                            this.$message.error(data.msg);
                        }
                    });
                })
                .catch(() => {
                    this.$message({
                        type: "info",
                        message: "已取消删除",
                    });
                });
            console.log("删除", data, node);
        }
    },
    created() {
        this.getCategory();
    },
};
</script>

<style>

</style>

测试删除数据和取消删除是否成功:

删除数据弹出是否删除
在这里插入图片描述

删除成功
在这里插入图片描述

取消删除
在这里插入图片描述

最后删除成功数据后Tree数据刷新及对应的Tree的默认展示父节点信息

在这里插入图片描述
绑定的属性
在这里插入图片描述
设置属性的值
在这里插入图片描述

好了,关于【20-业务开发-基础业务-商品模块-分类管理-前端展示后端具有层级关系的目录数据-商品系统三级分类的逻辑删除前后端代码实现】就先学习到这里,更多内容持续创作学习中!敬请期待。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/18835.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

JUC线程池——newSingleThreadExecutor源码解析JDK提供线程池ThreadPoolExecutor执行任务流程解析

newSingleThreadExecutor源码解析&&JDK提供线程池ThreadPoolExecutor执行任务流程解析测试代码核心代码解析ThreadPoolExecutor内部类&#xff1a;Worker解析调试台线程切换到执行异步任务的线程ThreadPoolExecutor&#xff1a;getTask()LinkedBlockingQueue&#xff1…

shell-函数

函数介绍 shell中有系统函数&#xff0c;也可以自定义函数 系统函数 basename basename [pathname] [suffix] 返回完整路径最后的/的部分&#xff0c;常用于获取文件名 basename命令会删掉所有的前缀包括最后一个/字符&#xff0c;然后将字符串显示出来 suffix为后缀&#…

java计算机毕业设计专业招聘网站(附源码、数据库)

java计算机毕业设计专业招聘网站&#xff08;附源码、数据库&#xff09; 项目运行 环境配置&#xff1a; Jdk1.8 Tomcat8.5 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技…

从零搭建个人博客项目并通过github部署上线

文章目录一、环境准备二、创建hexo博客项目1.全局安装hexo-cil工具2.新建hexo项目3.启动项目三、部署上线1.新建github仓库2.修改配置项3.部署项目一、环境准备 1.Node.js (版本需不低于 10.13) 2.Git https://hexo.io/zh-cn/ hexo博客官方文档 二、创建hexo博客项目 1.全局安…

dhtmlx甘特图marker不随小时移动

dhtmlx甘特图marker是什么&#xff1f; 就是一个跟着日期变化的标记&#xff0c;如下图所示 这段代码是用来调整标记的样式&#xff0c;展示文本的关键代码&#xff0c;如要配置今日标记&#xff0c;需在plugins添加maker后加上这段代码 start_date是用来获得日期的&#xf…

Ubuntu20单机搭建MongoDB4.2集群详细

文章目录 MongoDB文件下载选择你的服务器的安装路径配置文件启动服务集群配置MongoDB文件下载 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-ubuntu1604-4.2.23.tgz # 直接将版本号4.2.23换成自己需要的版本号即可 将文件下载到你的服务路径选择你的服务器…

《士兵突击》哪些最精彩的话语

目录 1、人不能过得太舒服&#xff0c;太舒服了容易出问题 2、别混日子了&#xff0c;小心日子把你给混了 3、想到和得到&#xff0c;中间还有两个字&#xff0c;那就是要做到 4、每做对一件小事&#xff0c;就被他像救命稻草一样抓着 5、我会带着问题生活&#xff0c;因为…

Qt 事件处理机制简介

1.Qt中事件的来源&#xff0c;谁接收处理。 Qt中事件的来源有两个&#xff1a;程序外部和内部&#xff0c;多数情况下来自操作系统&#xff0c;可以通过bool QEvent::spontaneous() const函数来获知&#xff0c;返回true&#xff0c;事件发生在应用程序之外(系统事件)&#xf…

SAP S4 FI后台详细配置教程- PART1 (通用配置及基础架构篇)

目录 一 、基础配置 3、设置国家区域 4、货币设置 二 、企业结构 1、定义公司 2、定义公司代码 3、维护成本控制范围 4、给公司分配公司代码 5、把公司代码分配给控制范围 本文是会是一篇比较详细文章&#xff0c;也是本人的学习记录。介绍如何在SAP从 0 到 1配置 一家公司 PAR…

虚拟机的 Ubuntu 没有 /dev/fb0 的解决办法

目录 一、概述 二、没有/dev/fb0的可能原因 三、解决过程 四、vesafb:mtrr,ywrap vga0x315的解释 一、概述 近期在学习FrameBuffer相关内容&#xff0c;想在Vmware虚拟机打开Ubuntu 12.04的系统使用一下&#xff0c;发现没有/dev/fb0的文件&#xff0c;于是上网搜索解决办法&…

数据结构之链表(带头双向循环链表)

文章目录前言一、带头双向循环链表二、双向链表的实现1.双向链表的定义2.双向链表的接口3.接口的实现创建返回链表的头结点创建一个新节点打印链表链表的销毁尾插尾删头插头删在链表中进行查找在pos前面插入数据链表删除pos位置处的节点4.主函数&#xff08;测试&#xff09;总…

vue-vuetify-admin案例讲解

vue-vuetify-admin案例讲解1. Introduction1.1 directory structure1.2 vue-cli1.3 vuex1.3.1 在store目录创建index.js1.3.2 在main.js中引入1.3.2 操作数据1.3.4 获取store中的值1.4 vue-router1.5 axios1.6 vuetify2. Code2.1 入门2.2 入门2.3 入门3. xxxvue-vuetify-admin:…

面试:常用的设计模式总结

一、Retrofit中的设计模式 二、OKHTTP中的设计模式 1、责任链模式interceptor拦截器&#xff1a;最主要的是5个拦截器 2、建造者&#xff1a;okhttp的client创建用了 3、观察者&#xff1a;返回结果抽离应该算是 4、工厂模式&#xff1a;Call 的创建用了工厂&#xff0c;Ca…

几何算法——10.欧拉操作

几何算法——10.欧拉操作1 欧拉操作1.1 欧拉操作的设计思想1.2 欧拉操作的选取1.3 几个典型的欧拉操作1.3.1 mvfs1.3.2 mev1.3.3 mef1.3.4 kemr1.3.5 kfmrh1.4 一个欧拉操作的实例1.5 欧拉操作的三点结论2. 非流形体2.1 非流形模型&#xff08;non-manifold model&#xff09;2…

动力节点索引优化解决方案学习笔记——性能分析

2. 性能分析 2.1 MySQL常见瓶颈 SQL中对大量数据进行比较、关联、排序、分组时CPU的瓶颈。 实例内存满足不了缓存数据或排序等需要&#xff0c;导致产生大量的物理IO。查询数据时扫描过多数据行&#xff0c;导致查询效率低。 2.2 Explain 使用EXPLAIN关键字可以模拟优化器执…

Super Vlan理论讲解

目录 Super Vlan作用 Super Vlan类型 Super Vlan通信规则 华为Super Vlan配置 传统Vlan部署中&#xff0c;一个Vlan对应一个网段和一个Vlanif接口来实现Vlan间的通信 造成了IP地址的浪费&#xff0c;因此提出了Super Vlan技术 Super Vlan作用 Super Vlan又称为聚合&#x…

java计算机毕业设计ssm金华学校社团管理系统

项目介绍 随着计算机信息技术的迅猛发展,互联网技术大规模应用到各行各业,传统的管理系统也逐渐精细化。高校作为教书育人的场所,各种管理也更应该智能化,特别是计算机信息专业更是最早接触信息技术,为高校各部门开发必要的系统是很有意义的事情。本金华学校社团管理系统对社团…

蓝桥杯刷题(二)

蓝桥杯刷题一.空间二.排序三.成绩分析四.蛇形填数五.跑步锻炼&#xff08;较难&#xff09;一.空间 这道题很简单&#xff0c;要弄清单位间的转换和如何输出就可以啦 #include <stdio.h>int main() {printf("%.0f",256/(32/4/2/1024.0000/1024));return 0; }记…

面试必学:输入 URL到页面的全过程-----五步完成、简单明了

目录 一、应用层解析 二、传输层连接 三、服务区处理 四、浏览器处理 五、断开 一、应用层解析 进行DNS解析&#xff1a;即将域名地址解析成 IP 地址 网络设备是通过 IP地址&#xff0c;作为身份标识 但是 IP地址不好记&#xff0c;所以很多时候就用一串单词 来进行表示。…

ipv6地址概述——深入讲解ipv6地址

作者简介&#xff1a;一名在校云计算网络运维学生、每天分享网络运维的学习经验、和学习笔记。 座右铭&#xff1a;低头赶路&#xff0c;敬事如仪 个人主页&#xff1a;网络豆的主页​​​​​​ 目录 前言 一.ipv6地址深入了解 1.ipv6地址表示 ①冒号十六进制表示法&am…