【21-业务开发-基础业务-商品模块-分类管理-商品系统三级分类的新增类别前后端代码实现-商品系统三级分类的更新类别前后端代码实现-之前错误的Bug修正】

news2025/1/15 21:08:02

一.知识回顾

【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网关模块的搭建-浏览器的同源策略与解决跨域问题实操案例】
【20-业务开发-基础业务-商品模块-分类管理-前端展示后端具有层级关系的目录数据-商品系统三级分类的逻辑删除前后端代码实现】

二.商品系统三级分类的新增类别

2.1 新增类别的后台实现

后端对应的controller接口
在这里插入图片描述

2.2 新增类别的前端实现

前端整体代码的逻辑整体实现:

<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.childrens.length != 0" 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>

        <!-- 添加 弹出框 -->
        <el-dialog title="提示" :visible.sync="dialogVisible" width="30%"
            :close-on-click-modal="false">
            <el-form :model="categoryForm">
                <el-form-item label="类别名称">
                    <el-input v-model="categoryForm.name" autocomplete="off"></el-input>
                </el-form-item>
                <el-form-item label="图标">
                    <el-input v-model="categoryForm.icon" autocomplete="off"></el-input>
                </el-form-item>
                <el-form-item label="计量单位">
                    <el-input v-model="categoryForm.productUnit" autocomplete="off"></el-input>
                </el-form-item>
            </el-form>
            <span slot="footer" class="dialog-footer">
                <el-button @click="dialogVisible = false">取 消</el-button>
                <el-button type="primary" @click="addDialog">确 定</el-button>
            </span>
        </el-dialog>
    </div>

</template>
  
<script>
/* eslint-disable */
export default {
    data() {
        return {
            dialogVisible: false,
            categoryForm: {},
            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)
        },
        //添加数据的方法
        append(data) {
            this.dialogVisible = true; // 打开弹出窗口
            // console.log("添加", data);
            this.categoryForm.parentCid = data.catId;// 添加的类别对应的父菜单
            this.categoryForm.catLevel = data.catLevel + 1; // 设置添加类别的层级
            this.categoryForm.showStatus = 1; // 菜单的显示状态  1 显示  0 被删除
            this.categoryForm.sort = 0; // 排序 默认给 0 
        },
        //添加商品类别的方法
        addDialog() {
            // 添加三级分类的类别信息
            this.$http({
                url: this.$http.adornUrl("/product/category/save"),
                method: "post",
                data: this.$http.adornData(this.categoryForm, false),
            }).then(({ data }) => {
                if (data && data.code === 0) {
                    this.$message({
                        message: "数据添加成功",
                        type: "success",
                    });
                    this.dialogVisible = false; // 关闭弹出窗口
                    // 重新加载所有的菜单数据
                    this.getCategory();
                    // 设置默认展开的父节点信息
                    this.expandKeys = [this.categoryForm.parentCid];
                } else {
                    this.$message.error(data.msg);
                }
            });
        },
        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>

下面是前端代码整体实现的一些逻辑细节操作:

对话框页面----》从Element-UI官方查找

image.png
弹出对话框后,防止点击其它位置对话框直接关闭,设置这个属性
在这里插入图片描述

后端接口方法需要的是一个对象,前端设置属性categoryForm{}以及对话框是否弹出的属性dialogVisable,默认为false,不弹出,只有点击后才弹出。
在这里插入图片描述

点击添加后弹出页面,设置append方法

image.png

完成表单数据提交的ajax请求—对应我们的addDialog方法

在这里插入图片描述

2.3 添加类别访问测试

添加数据
在这里插入图片描述

添加数据成功显示
在这里插入图片描述

三.商品系统三级分类的更新类别

3.1 后端逻辑实现

后端更新逻辑接口
在这里插入图片描述
后端根据商品分类的id查询商品实体对象
在这里插入图片描述

注意:补充之前代码的一个Bug

如果在二级分类下面添加三级分类,然后添加的三级分类不能显示。原因在Java后端中的Long类型数据的比较。只需要修改相关代码即可

image.png

出错原因

在这里插入图片描述

3.2 前端逻辑实现

全局属性的设置
在这里插入图片描述
先更新一下append的方法并设置相关的属性

在这里插入图片描述

新增加更新的功能
在这里插入图片描述

点击更新,进入edit的函数

在这里插入图片描述

既有新增,也有更新,通过定义一个submitForm函数来包装俩个子函数(addDialog新增—editDialog更新)
在这里插入图片描述

包装函数的接口—submitForm
在这里插入图片描述
新增函数接口----addDialog

在这里插入图片描述
更新函数接口-----editDialog
在这里插入图片描述

前端代码整体实现:

<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 type="text" size="mini" @click="() => edit(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>

        <!-- 添加 弹出框 -->
        <el-dialog :title="dialogType ? '新增' : '更新'" :visible.sync="dialogVisible" width="30%"
            :close-on-click-modal="false">
            <el-form :model="categoryForm">
                <el-form-item label="类别名称">
                    <el-input v-model="categoryForm.name" autocomplete="off"></el-input>
                </el-form-item>
                <el-form-item label="图标">
                    <el-input v-model="categoryForm.icon" autocomplete="off"></el-input>
                </el-form-item>
                <el-form-item label="计量单位">
                    <el-input v-model="categoryForm.productUnit" autocomplete="off"></el-input>
                </el-form-item>
            </el-form>
            <span slot="footer" class="dialog-footer">
                <el-button @click="dialogVisible = false">取 消</el-button>
                <el-button type="primary" @click="submitForm">确 定</el-button>
            </span>
        </el-dialog>
    </div>

</template>
  
<script>
/* eslint-disable */
export default {
    data() {
        return {
            dialogType: false, //true 表示增加  false 表示更新
            dialogVisible: false, //打开弹出窗口 false 不打开  true 打开
            categoryForm: { name: null, icon: null, productUnit: null, showStatus: 1, sort: 0, catId: null, catLevel: 1 },
            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)
        },
        //添加数据的方法
        append(data) {
            //this.dialogType = true;
            this.dialogVisible = true; // 打开弹出窗口
            // console.log("添加", data);
            this.categoryForm.parentCid = data.catId;// 添加的类别对应的父菜单
            this.categoryForm.catLevel = data.catLevel + 1; // 设置添加类别的层级
            this.categoryForm.showStatus = 1; // 菜单的显示状态  1 显示  0 被删除
            this.categoryForm.sort = 0; // 排序 默认给 0 

            // 重置更新的数据
            this.categoryForm.catId = null;
            this.categoryForm.name = "";
            this.categoryForm.icon = "";
            this.categoryForm.productUnit = "";
            // 更新状态
            this.dialogType = true;
        },
        //添加商品类别的方法
        addDialog() {
            // 添加三级分类的类别信息
            this.$http({
                url: this.$http.adornUrl("/product/category/save"),
                method: "post",
                data: this.$http.adornData(this.categoryForm, false),
            }).then(({ data }) => {
                if (data && data.code === 0) {
                    this.$message({
                        message: "数据添加成功",
                        type: "success",
                    });
                    this.dialogVisible = false; // 关闭弹出窗口
                    // 重新加载所有的菜单数据
                    this.getCategory();
                    // 设置默认展开的父节点信息
                    this.expandKeys = [this.categoryForm.parentCid];
                } else {
                    this.$message.error(data.msg);
                }
            });
        },
        editDialog() {
            // 更新三级分类的类别信息
            this.$http({
                url: this.$http.adornUrl("/product/category/update"),
                method: "post",
                data: this.$http.adornData(this.categoryForm, false),
            }).then(({ data }) => {
                if (data && data.code === 0) {
                    this.$message({
                        message: "数据更新成功",
                        type: "success",
                    });
                    this.dialogVisible = false; // 关闭弹出窗口
                    // 重新加载所有的菜单数据
                    this.getCategory();
                    // 设置默认展开的父节点信息
                    this.expandKeys = [this.categoryForm.parentCid];
                } else {
                    this.$message.error(data.msg);
                }
            });
        },
        edit(data) {
            this.dialogType = false;
            // 获取最新的数据回写
            this.$http({
                url: this.$http.adornUrl(`/product/category/info/${data.catId}`),
                method: "post",
                data: this.$http.adornData(this.categoryForm, false),
            }).then(({ data }) => {
                console.log("获取的数据", data)
                // 表单数据回写
                this.categoryForm.name = data.category.name;
                this.categoryForm.productUnit = data.category.productUnit;
                this.categoryForm.icon = data.category.icon;
                this.categoryForm.catLevel = data.category.catLevel;
                this.categoryForm.parentCid = data.category.parentCid;
                // 填充更新数据的id
                this.categoryForm.catId = data.category.catId;
                this.categoryForm.showStatus = 1;
                this.categoryForm.sort = 0;

                // 更新类别信息的方法
                this.dialogVisible = true; // 打开更新的窗口
            });
        },
        submitForm() {
            console.log("dialogType", this.dialogType)
            // 判断当前的操作是添加还是更新
            if (this.dialogType) {
                // 添加操作
                this.addDialog();
            } else {
                // 更新操作
                this.editDialog();
            }
        },
        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>

3.3 测试

新建一个二级分类
在这里插入图片描述

在刚建立的二级分类下新建立三级分类
在这里插入图片描述

更新三级分类的图标和计量单位
在这里插入图片描述
删除三级分类
在这里插入图片描述

好了,关于【21-业务开发-基础业务-商品模块-分类管理-商品系统三级分类的新增类别前后端代码实现-商品系统三级分类的更新类别前后端代码实现-之前的Bug修正】就先学习到这里,更多内容持续创作更新中,敬请期待。

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

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

相关文章

2022 全网最全最新 Java 面试题 - 独家内部教材

怎样才能拿到大厂的 offer&#xff0c;没有掌握绝对的技术&#xff0c;那么就要不断的学习 从疫情破局而出&#xff0c;又在毕业季一路过关斩将&#xff0c;我是如何笑面试官&#xff0c;拿到阿里&#xff0c;腾讯等八家大厂的 offer 的呢&#xff0c;在这里分享我的秘密武器&…

kubernetes(K8S)学习笔记P3:集群 YAML 文件(部署)

集群 YAML 文件&#xff08;部署&#xff09;4.集群 YAML 文件&#xff08;部署&#xff09;4.1 YAML 文件概述4.2YAML 文件书写格式4.2.1YAML 介绍4.2.2YAML 基本语法4.2.3YAML 支持的数据结构4.3资源清单描述方法4.3.1常用字段4.3.2字段解释4.4快速编写yml-->kubdectl cre…

数据结构由中序序列和后序序列构造二叉树

2022.11.19 由中序序列和后序序列构造二叉树任务描述相关知识编程要求测试说明C/C代码任务描述 本关任务要求采用中序遍历序列和后序遍历序列构造二叉树。 相关知识 给定一棵二叉树的中序遍历序列和后序遍历序列可以构造出这棵二叉树。例如后序序列是DEBFGCA&#xff0c;中序…

MySQL8.0优化 - 锁 - 从对待锁的态度划分:乐观锁、悲观锁

文章目录学习资料锁的不同角度分类锁的分类图如下从对待锁的态度划分&#xff1a;乐观锁、悲观锁悲观锁&#xff08;Pessimistic Locking&#xff09;乐观锁&#xff08;Optimistic Locking&#xff09;两种锁的适用场景学习资料 【MySQL数据库教程天花板&#xff0c;mysql安装…

Ajax笔记

Ajax笔记资源的请求方式一、概念1、Ajax作用2、jQuery中的Ajax二、$.get()函数的语法$.get()发起不带参数的请求$.get()发起带参数的请求三、$.post()函数的语法$.post()向服务器提交数据<font colorred>四、$.ajax()函数的语法使用$.ajax()发起GET请求使用$.ajax()发起P…

JSP使用

目录 简介 作用 创建 结构 常用脚本 声名脚本 表达式脚本 代码脚本 注释 九大内置对象 四大域对象 out与response.getWriter 静态引入 动态引入 EL表达式 作用 语法 取值顺序 获取指定参数 输出指定对象的数据 运算符 算数运算符 关系比较 逻辑运算符…

【Vue】使用 axios 发送ajax 请求

在 Vue 里面我们如何去发送一些 Ajax(阿贾克斯)请求 从远程的网站上获取一些数据。 假如我们有这样的接口的地址&#xff1a; https://www.xxxx.site 假设它是一个能跨域访问的接口。‍‍‍‍ 如果我们想去在我们的代码里面发这种请求&#xff0c;我该怎么做&#xff1f; 首…

Ubuntu 桌面系统升级

本文介绍 Ubuntu 桌面系统升级的两种方式&#xff0c;通过 UI 或命令行的方式&#xff0c;演示为 20.04 升级为 22.04。并介绍了 windows 的 Linux 子系统 wsl 的升级注意事项。 背景 之前在学习 ROS2 时&#xff0c;安装 ros-humble-desktop 出现依赖错误&#xff1a;无法修正…

[附源码]java毕业设计食材采购平台论文

项目运行 环境配置&#xff1a; Jdk1.8 Tomcat7.0 Mysql HBuilderX&#xff08;Webstorm也行&#xff09; Eclispe&#xff08;IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持&#xff09;。 项目技术&#xff1a; SSM mybatis Maven Vue 等等组成&#xff0c;B/S模式 M…

AI智工作室11.19练习题解

F CodeForces - 710A 训练1(共12题) - Virtual Judge 我的代码 #include<iostream> using namespace std; int main() {char arr[10][10],a;int b,c,k0;cin>>a>>c; ba-a1; // cout<<b<<" "<<c<<endl; for(int i0;i<9…

使用VSCode编辑与编译WSL2下源代码

1. 安装WSL2 2. windows下安装VSCode 3. VSCode安装插件Remote Development 北京时间2019年5月3日&#xff0c;在 PyCon 2019 大会上&#xff0c;微软发布了 VS Code Remote&#xff0c;开启了远程开发的新时代&#xff01;这次发布包含了三款核心的全新插件&#xff0c;它们…

Java文件操作【教你用Java运行微信】

文章目录01 创建文件02 获取文件信息03 目录操作和文件删除04 运行可执行文件01 创建文件 new File(String pathname) //根据路径创建一个File对象&#xff1b;new File(File parent,String child) //根据父目录文件子路径创建&#xff1b;new File(String parent,String chil…

使用mqtt.fx向EMQX服务器发送消息

摘要&#xff1a;本文介绍如何使用mqtt.fx向mqtt服务器&#xff08;EMQX&#xff09;发送消息。顺便介绍一下labview与EMQX连接成功的实现效果。 上一篇文章介绍了如何在ubuntu下安装emqx服务器&#xff0c;以及如何使用mqtt.fx订阅服务器上的一个主题。 ubuntu系统下搭建本地…

为什么ArcGIS添加的TIFF栅格数据是一片纯色

下面来介绍一下今天的正式内容&#xff1a;为什么你添加的tiff栅格数据明明有数据&#xff0c;为什么却在GIS中显示一片颜色。 即使你去拉伸后 他还是显示这样&#xff1f; 那如何才能让他正常显示呢&#xff1f; 逻辑其实是简单的。我们检查数据会发现&#xff0c;这份数据等…

Springboot集成HBase使用案例

一、HBase部署安装 1.HBase下载地址:Apache HBase – Apache HBase Downloads 2.解压启动(进入压缩包bin目录),本次演示的是macOS系统启动演示(windows系统启动命令:./start-hbase.cmd) ./start-hbase.sh 3. 浏览器访问http://IP:16010/master-status出现如下页面表示启动成功…

线程基础知识复习

线程基础知识复习 并发相关Java包 涉及到的包内容 java.util.concurrentjava.util.concurrent.atomicjava.util.concurrent.locks 并发始祖 并发始祖Doug Lea start线程解读 初始程序 public static void main(String[] args) {Thread t1 new Thread(() ->{},"t…

涛涛的Linux学习笔记

前言&#xff1a; 因为自己偏向Java后端开发&#xff0c;接触linux有一段时间了&#xff0c;但从来没系统的学过&#xff0c;用啥学啥&#xff0c;所以一直感觉体系不全&#xff0c;现在补补日常能用到的。 一、Linux的定位 二、Linux系统的目录结构 目录结构描述/根目录&#…

【云原生】Docker的初步认识,安装与基本操作

内容预知 1.docker的相关知识 1.1 docker的概念 1.2 docker三个重要概念 &#xff08;1&#xff09;image镜像 &#xff08;2&#xff09;container容器 &#xff08;3&#xff09;repostory仓库 1.3 docker的主要用途 1.4 docker与虚拟机的区别 namesapce&#xff…

STM32F334timer6-7

STM32F334timer6-7概况预分频器描述计数模式时钟概况 基本计时器&#xff08;TIM6/TIM7&#xff09;功能包括&#xff1a; •16位自动重新加载递增计数器 •16位可编程预分频器&#xff0c;用于将计数器时钟频率除以1和65535之间的任何因子&#xff08;也可“动态”&#xff0…

立方体贴图shade计算

正常的平面贴图是根据mesh顶点找到对应的uv坐标&#xff0c;然后根据重心坐标插值计算三角面内每个点的uv坐标值。最后根据uv坐标值查找平面贴图上的颜色值。 立方体贴图的6个面分别为6张图片&#xff0c;我们怎么根据mesh面上的坐标值来计算对应平面上的uv坐标值。 基本算法是…