谷粒商城实战-58-商品服务-API-三级分类-删除-批量删除小结

文章目录

  • 一,增加一个批量删除的按钮并绑定事件
  • 二,全栈工程师
  • 三,逆向工程在全栈开发中的应用
    • 提升效率的方式:
    • 使用案例:

这一节的主要内容是开发批量删除分类的功能。

一,增加一个批量删除的按钮并绑定事件

在这里插入图片描述

  <el-button type="danger" @click="batchDelete">批量删除</el-button>

为了使用el-tree的方法获取选中的节点,需要给el-tree一个引用属性ref

在这里插入图片描述

绑定的注册事件如下。

batchDelete() {// 1,获取被选中的结点var checkedNodes = this.$refs.tree.getCheckedNodes();if (checkedNodes.length === 0) {this.$message.error("请先选需要删除的分类");return;}// 2,将被选中的结点的catId接成一个数组,并作为参数,调用后端接口,删除这些结点var catIds = checkedNodes.map((node) => node.data.catId);this.$http({url: this.$http.adornUrl("/product/category/delete"),method: "post",data: this.$http.adornData(catIds, false),}).then(({ data }) => {if (data && data.code === 0) {this.$message({message: "操作成功",type: "success",duration: 1500,onClose: () => {console.log("删除成功,关闭消息提示");this.getMenus(); // 重新获取数据},});} else {this.$message.error(data.msg);}});},

这段代码是一个用于批量删除选定节点的功能,它是在一个前端Vue.js应用中实现的。下面是对这段代码的详细解释:

  1. 获取被选中的结点:

    var checkedNodes = this.$refs.tree.getCheckedNodes();
    
    • this.$refs.tree 是一个对Vue组件内部元素或子组件的引用,在这里应该是指向了一个树形控件。
    • getCheckedNodes() 是这个树形控件的一个方法,用来获取所有被选中的节点。
  2. 检查是否有结点被选中:

    if (checkedNodes.length === 0) {this.$message.error("请先选需要删除的分类");return;
    }
    
    • 如果没有节点被选中,则通过 this.$message.error 显示一条错误消息,并返回,不执行后续操作。
  3. 提取选中结点的ID:

    var catIds = checkedNodes.map((node) => node.data.catId);
    
    • map 方法用于遍历 checkedNodes 数组,并为每个节点提取 catId 属性。catId 假设是节点数据中的一个属性,表示类别ID。
  4. 发送HTTP请求删除结点:

    this.$http({url: this.$http.adornUrl("/product/category/delete"),method: "post",data: this.$http.adornData(catIds, false),
    }).then(({ data }) => {// ...
    });
    
    • 使用 $http 发送一个POST请求到 /product/category/delete URL,用于删除指定的类别。
    • this.$http.adornUrlthis.$http.adornData 可能是自定义的方法,用于处理URL和数据,比如添加一些额外的信息或者格式化数据。
    • catIds 被传递给 adornData 方法作为数据体。
  5. 处理响应结果:

    • 如果服务器返回的状态码是 0,则认为操作成功,并显示一条成功消息。
    if (data && data.code === 0) {this.$message({message: "操作成功",type: "success",duration: 1500,onClose: () => {console.log("删除成功,关闭消息提示");this.getMenus(); // 重新获取数据},});
    } else {this.$message.error(data.msg);
    }
    
    • 成功消息会在1.5秒后自动关闭,并调用 this.getMenus 方法重新获取数据。
    • 如果返回的状态码不是 0,则显示一条错误消息,其中 data.msg 应该包含了具体的错误信息。

二,全栈工程师

全栈工程师的工作内容通常涵盖了从前端用户界面开发到后端服务器逻辑与数据库管理的整个软件开发过程。具体来说,他们的职责可能包括但不限于以下几个方面:

  1. 前端开发:

    • 开发和维护网站的用户界面(UI)和用户体验(UX)。
    • 使用HTML、CSS、JavaScript等技术构建响应式和交互式的网页。
    • 集成前端框架和库,如React、Angular或Vue.js。
  2. 后端开发:

    • 设计和实现服务器端逻辑。
    • 开发RESTful API接口。
    • 数据库设计、优化查询性能。
    • 使用Node.js、Python、Java、Ruby等语言编写后端服务。
  3. 系统架构:

    • 设计可扩展的应用程序架构。
    • 选择合适的技术栈和技术方案。
  4. 测试与部署:

    • 编写自动化测试脚本。
    • 执行单元测试、集成测试和系统测试。
    • 部署应用程序到生产环境。
  5. 持续集成/持续部署 (CI/CD):

    • 实施持续集成流程。
    • 使用Docker容器化应用。
    • 配置自动化部署管道。
  6. 安全性:

    • 实现安全措施来保护应用程序免受攻击。
    • 加密敏感数据。
    • 遵守数据保护法规。
  7. 性能优化:

    • 优化前端加载速度和用户体验。
    • 优化数据库查询和缓存策略。
    • 监控应用性能并进行调优。
  8. 故障排查与维护:

    • 解决生产环境中出现的问题。
    • 维护现有系统并修复bug。

接下来,我们来谈谈逆向工程如何帮助全栈工程师提升效率,特别是在根据数据库表结构生成前后端代码的场景下:

三,逆向工程在全栈开发中的应用

逆向工程在这个上下文中指的是从现有的数据库表结构生成相应的前后端代码。这可以通过一些工具或框架实现,例如通过数据库映射工具来生成实体类、数据访问层、前端表格等。这种方法可以显著减少开发时间,因为很多基础性的代码不需要手动编写。

提升效率的方式:

  1. 减少重复工作:

    • 自动生成的代码可以避免手动编写常见的CRUD操作,减少开发人员的工作量。
    • 自动化的表单和页面布局减少了前端开发的时间。
  2. 快速原型制作:

    • 快速生成基本功能的原型,便于团队进行讨论和迭代。
    • 更快地展示给客户或利益相关者,以获得反馈。
  3. 一致性:

    • 生成的代码遵循一致的编码风格和标准,有助于保持项目的整洁性和可维护性。
  4. 易于修改和扩展:

    • 生成的基础代码可以轻松地进行修改以适应特定需求。
    • 通过添加自定义逻辑来扩展功能。
  5. 文档和注释:

    • 自动生成的代码通常会附带基本的注释和文档,有助于新加入团队的成员更快地上手。
  6. 错误减少:

    • 由工具生成的代码通常比手工编写的代码更少出错。
    • 代码生成器可以帮助遵守最佳实践和编码规范。

使用案例:

  • 后端服务:

    • 从数据库表结构生成对应的模型类(Model)、数据访问对象(DAO)、服务层(Service)等。
    • 自动生成RESTful API接口。
  • 前端应用:

    • 生成基于数据库表的表单和列表视图。
    • 创建响应式用户界面,与后端API对接。

通过这种方式,逆向工程不仅能够提高开发效率,还能确保代码质量和项目的一致性。然而,值得注意的是,虽然逆向工程可以提供很好的起点,但开发人员仍然需要根据实际业务需求对生成的代码进行调整和完善。

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

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

相关文章

树莓派智能家居中枢

一个先进的枢纽&#xff0c;使智能家居系统更智能、更可定制、更易于控制 Homey Pro由树莓派 Compute Module 4 供电,Homey Pro 为用户提供了一个单一界面,用于控制和监控来自不同品牌的所有智能家居设备。它完全在本地网络上运行,而不是依赖云端,从而实现了最低的延迟、最高的…

【数据结构】单链表的增删改查

介绍 链表是有序的列表&#xff0c;但是它在内存中是如下存储的&#xff1a; ①链表以节点的方式进行存储&#xff0c;是链式存储的 ②每个节点包含 data 域、next 域&#xff1a;指向下一节点 ③链表的各个节点不一定是连续存放的 ④链表分为有头节点的链表和没有头节点的链表…

netty入门-6 Handler和Pipeline

前言 书上讲服务器客户端创建三个要点&#xff0c;线程模型(Group)&#xff0c;IO模型(NioSocketChannel)&#xff0c;处理逻辑。 这篇的Handler和Pipeline&#xff0c;就是我们IO操作的处理逻辑。 然后下篇说ByteBuf这个Netty自己实现的数据封装组件。 Handler和Pipeline 我…

GAT知识总结

《GRAPH ATTENTION NETWORKS》 解决GNN聚合邻居节点的时候没有考虑到不同的邻居节点重要性不同的问题&#xff0c;GAT借鉴了Transformer的idea&#xff0c;引入masked self-attention机制&#xff0c; 在计算图中的每个节点的表示的时候&#xff0c;会根据邻居节点特征的不同来…

57 数据链路层

用于两个设备&#xff08;同一种数据链路节点&#xff09;之间传递 目录 对比理解“数据链路层” 和 “网络层”以太网 2.1 认识以太网 2.2 以太网帧格式MAC地址 3.1 认识MAC地址 3.2 对比理解MAC地址和IP地址局域网通信MTU 5.1 认识MTU 5.2 MTU对ip协议的影响 5.3 MTU对UDP的…

javafx的ListView代入项目的使用

目录 1. 创建一个可观察的列表&#xff0c;用于存储ListView中的数据,这里的User是包装了用户的相关信息。 2.通过本人id获取friendid&#xff0c;及好友的id&#xff0c;然后用集合接送&#xff0c;更方便直观一点。 3.用for遍历集合&#xff0c;逐个添加。 4.渲染器&…

非凸T0算法,如何获取超额收益?

什么是非凸 T0 算法&#xff1f; 非凸 T0 算法基于投资者持有的股票持仓&#xff0c;利用机器学习等技术&#xff0c;短周期预测&#xff0c;全自动操作&#xff0c;抓取行情波动价差&#xff0c;增厚产品收益。通过开仓金额限制、持仓时长控制等&#xff0c;把控盈亏风险&…

MySQL练习05

题目 步骤 触发器 use mydb16_trigger; #使用数据库create table goods( gid char(8) primary key, name varchar(10), price decimal(8,2), num int);create table orders( oid int primary key auto_increment, gid char(10) not null, name varchar(10), price decima…

基于Python的二手房价格分析与多种机器学习房价预测

需要本项目的同学可以私信我&#xff0c;提供部署讲解服务和文档 近年来&#xff0c;中国各个城市的房价问题一直是人们所关心的焦点之一。随着新建房价的不断上涨&#xff0c;城市内建筑新房的用地也越来越少&#xff0c;加上对房屋刚性的需求&#xff0c;人民群众对二手房的…

rust 初探 -- use

rust 初探 – use Package, Crate, 定义 Module use 关键字 作用&#xff1a;将路径引入到作用域内&#xff0c;其依旧遵循私有性规则&#xff0c;也即只用 pub 的部分引入进来才能使用 use crate::front_of_house::hosting; // 绝对路径 // use front_of_house::hosting; …

爬取贴吧的标题和链接

免责声明 感谢您学习本爬虫学习Demo。在使用本Demo之前&#xff0c;请仔细阅读以下免责声明&#xff1a; 学习和研究目的&#xff1a;本爬虫Demo仅供学习和研究使用。用户不得将其用于任何商业用途或其他未经授权的行为。合法性&#xff1a;用户在使用本Demo时&#xff0c;应确…

个性化音频生成GPT-SoVits部署使用和API调用

一、训练自己的音色模型步骤 1、准备好要训练的数据&#xff0c;放在Data文件夹中&#xff0c;按照文件模板中的结构进行存放数据 2、双击打开go-webui.bat文件&#xff0c;等待页面跳转 3、页面打开后&#xff0c;开始训练自己的模型 &#xff08;1&#xff09;、人声伴奏分…

关于sqlite数据库转化mysql数据

使用工具 下图所使用的为navivat premium 16数据库管理工具。 如下图所示为sqlite数据库db数据 下图为所设计的sqlite数据表格字段属性 首先导出sql语句 打开工具栏中的数据传输功能。 如上图所示&#xff0c;选择目标选为文件&#xff0c;并且将默认勾选的与源服务器相同…

oracle读写时相关字符集详解

服务器端操作系统&#xff08;Oracle linux&#xff09;字符集 服务器端数据库字符集 客户端操作系统&#xff08;Oracle linux&#xff09;字符集 客户端工具sqlplus字符集 结论1&#xff1a;客户端工具sqlplus的会话&#xff0c;使用的字符集&#xff0c;是数据库字符集。…

Android 15 适配整理——实践版

背景 谷歌发布Android 15后&#xff0c;国内的手机厂商迅速行动&#xff0c;开始了新系统的适配工作。小米、OPPO、vivo和联想等金标联盟成员联合发布了适配公告&#xff0c;督促APP开发者在2024年8月31日前完成适配工作&#xff0c;否则将面临搜索标签提示、应用降级、分机型…

zookeeper开启SASL权限认证

目录 一、SASL介绍 二、使用 SASL 进行身份验证 2.1 服务器到服务器的身份验证 2.2 客户端到服务器身份验证 三、验证功能 一、SASL介绍 默认情况下&#xff0c;ZooKeeper 不使用任何形式的身份验证并允许匿名连接。但是&#xff0c;它支持 Java 身份验证与授权服务(JAAS)…

学习日记:数据类型2

目录 1.转义字符 2.隐式类型转换 2.1 强制类型转换 2.2 不同类型间赋值 3.运算符 表达式 3.1 算术运算符 3.2 算术运算优先级 3.3 赋值运算 3.3.1 不同类型间混合赋值 3.4 逗号运算 4.生成随机数 5. 每日一练 1.转义字符 \n 表示换行 \t …

3.2、数据结构-数组、矩阵和广义表

数组结构 数组是定长线性表在维度上的扩展,即线性表中的元素又是一个线性表。N维数组是一种“同构”的数据结构,其每个数据元素类型相同、结构一致。 一个m行n列的数组表示如下: 其可以表示为行向量形式&#xff08;一行一行的数据&#xff09;或者列向量形式&#xff08;一…

【Python第三方库】PyQt5安装与应用

文章目录 引言安装PYQT5基于Pyqt5的简单桌面应用常用的方法与属性QtDesigner工具使用与集成窗口类型QWidget和QMainWindow区别 UI文件加载方式直接加载UI文件的方式显示窗口转化py文件进行显示窗口 PyQt5中常用的操作信号与槽的设置绑定页面跳转 引言 PyQt5是一个流行的Python…

自动化测试--WebDriver API

1. 元素定位方法 通过 ID 定位&#xff1a;如果元素具有唯一的 ID 属性&#xff0c;可以使用 findElement(By.id("elementId")) 方法来定位元素。通过 Name 定位&#xff1a;使用 findElement(By.name("elementName")) 来查找具有指定名称的元素。通过 Cl…