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

news2024/11/23 19:40:53

文章目录

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

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

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

在这里插入图片描述

  <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://www.coloradmin.cn/o/1953513.html

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

相关文章

数论第一节:整数的可除性

[TOC ] 1、整除的概念 整除&#xff1a; 设a&#xff0c;b∈Z&#xff0c;若存在整数c∈Z&#xff0c;s.t. a bc&#xff0c;则称b整除a&#xff0c;记为 b ∣ a b|a b∣a否则称b不整除a。 带余除法&#xff1a; 设 a &#xff0c; b ∈ z a&#xff0c;b∈z a&#xff0c;b∈…

Jupyter notebook无法自动关联打开浏览器,怎么办?

最近为了方便进行数据分析和处理&#xff0c;在电脑上安装了Anaconda。 Anaconda 是一个功能强大的数据科学平台&#xff0c;它包含了‌conda、Python以及180多个科学包及其依赖项。 Anaconda 常常用于科学计算、数据分析和人工智能等领域&#xff0c;并且得到了广大开发者的…

【中项】系统集成项目管理工程师-第5章 软件工程-5.5部署交付

前言&#xff1a;系统集成项目管理工程师专业&#xff0c;现分享一些教材知识点。觉得文章还不错的喜欢点赞收藏的同时帮忙点点关注。 软考同样是国家人社部和工信部组织的国家级考试&#xff0c;全称为“全国计算机与软件专业技术资格&#xff08;水平&#xff09;考试”&…

界面控件Telerik UI for WPF 2024 Q2亮点 - 全新的AIPrompt组件

Telerik UI for WPF拥有超过100个控件来创建美观、高性能的桌面应用程序&#xff0c;同时还能快速构建企业级办公WPF应用程序。UI for WPF支持MVVM、触摸等&#xff0c;创建的应用程序可靠且结构良好&#xff0c;非常容易维护&#xff0c;其直观的API将无缝地集成Visual Studio…

PostgreSQL成为最受欢迎的数据库; TiDB马拉松大赛开启, Serverless和Vector为比赛焦点

重要更新 1. TiDB Hackathon大赛报名开启&#xff0c;总奖金达21万&#xff0c;主题是基于 TiDB Serverless 内置的向量搜索功能&#xff08;Vector Search&#xff09;构建 AI 创新应用&#xff0c;感兴趣的可以报名参加。( [1] ) 2. Stack Overflow 2024 开发者调研结果公布…

Java面试还看传统八股文?快来看看这个场景题合集吧【附PDF】

以下就是这份面试场景文档↓ 这里有什么&#xff1f; ↓↓ 1.针对 2024 年面试行情的变化设计的面试场景题以及回答思路 2. 如何快速通过面试的详细攻略 3. 简历优化技巧 1.知己知彼才能百战百胜&#xff0c;如何做好面试前的准备工作 场景题答案以及更多场景题八股文一线大…

注意力机制(三)- 空间注意力机制

空间注意力的核心思想是让模型能够聚焦于输入数据中最重要的空间区域 关注区域&#xff1a; 空间注意力机制使模型能够识别并关注输入图像或文本中的关键区域。 权重分配&#xff1a; 通过学习一个权重分布&#xff0c;模型可以为输入数据的每个空间位置分配不同的重要性。这些…

刷题了:150. 逆波兰表达式求值 |239. 滑动窗口最大值 |347.前 K 个高频元素

150. 逆波兰表达式求值 题目链接:https://leetcode.cn/problems/evaluate-reverse-polish-notation/description/ 文章讲解:https://programmercarl.com/0150.%E9%80%86%E6%B3%A2%E5%85%B0%E8%A1%A8%E8%BE%BE%E5%BC%8F%E6%B1%82%E5%80%BC.html 视频讲解:https://www.bilibili.…

食品管理系统

目录 第1章 系统概述 第2章 可行性研究 2.1 项目背景及意义 2.2 可行性研究 第3章 需求分析 3.1 功能性需求 第4章 总体设计 4.1 系统的功能模块图。 4.2各功能模块简介 4.3主要业务流程 第5章 详细设计 5.1 食品管理系统页面 5.2个人中心页面 5.3 系统管理页面 …

Linux编程:使用python或者shell获取系统信息

0. 概要 在日常的系统管理和性能监控中&#xff0c;获取系统信息是一个非常常见的需求。 本文将介绍如何使用Python和Shell脚本来获取这些系统信息。 1. 使用Python获取系统信息 使用psutil库来获取系统的CPU、内存、磁盘和网络信息。 1.1 安装psutil库 首先&#xff0c;我…

论文阅读——Wirelessly-Powered Wireless Sensor Platform

文章目录 摘要一、整流天线二、仿真结果三、系统测试总结 论文来源&#xff1a;https://ieeexplore.ieee.org/document/4403991 摘要 文章介绍了一种低功耗&#xff08;约10μW&#xff09;的2.45 GHz无线传感器平台&#xff0c;该平台包括一个三轴加速度计、温度计和皮肤电导…

开源大模型的格式转成GGUF,并量化后使用ollama推理

https://github.com/ggerganov/llama.cpphttps://github.com/ggerganov/llama.cpp使用到的工具: llama.cpp ollama 步骤 1、下载llama.cpp,并使用make编译 2、新建conda环境,安装llama.cpp里所需的库(requirements.txt) 3、下载需要量化的模型

15.C语言形式参数和实际参数的介绍及函数总结

形参和实参的介绍及函数总结 1.形式参数和实际参数2.获取两个最大的数3.关于函数的一些总结 1.形式参数和实际参数 实际参数可以是常量、变量、表达式 y get(1);//常量 y get(x);//变量 y get(x1);//表达式形参和实参数值相同&#xff0c;地址不同(传递参数是数值的传递)。 …

全能数据分析工具:Tableau Desktop 2019 for Mac 中文激活版

Tableau Desktop 2019 一款专业的全能数据分析工具&#xff0c;可以让用户将海量数据导入并记性汇总&#xff0c;并且支持多种数据类型&#xff0c;比如像是编程常用的键值对、哈希MAP、JSON类型数据等&#xff0c;因此用户可以将很多常用数据库文件直接导入Tableau Desktop&am…

python_基础编程_字典、集合

字典类型&#xff1a; 一、什么是字典 字典&#xff1a;是py内置的数据结构之一&#xff0c;与列表一样是一个可变的序列&#xff0c;以键值对的方式存储数据&#xff0c;是一个无序的序列 二、字典的原理 实现原理&#xff1a;Py根据key查找value所在的位置 三、字典的创…

Redhat 7.9上配置达梦数据库的DM 数据守护(DM Data Watch)

Redhat 7.9上配置达梦数据库的DM 数据守护&#xff08;DM Data Watch&#xff09; 一 基础环境 端口说明&#xff1a; 注&#xff1a; 主库已经安装软件&#xff0c;及创建数据库实例。并已开启归档模式。 [dmdbatest1 tool]$ disql sysdba/Dameng123 服务器[LOCALHOST:523…

Cuda入门

文章目录 下载使用NsightAPI__ldg 函数实现1. Sigmoid2. warpReduceSum 参考学习资料 下载使用Nsight https://developer.nvidia.com/nsight-systems/get-startedsudo ln -s /opt/nvidia/nsight-systems/2024.4.1/bin/nsys /bin/nsysnsys profile --statstrue addAPI __ldg …

kotlin协程-- 基础概念 ①|创建和使用

引言 首先先说一些相关概念 1.并发与并行 在操作系统中我们曾经学到过并发与并行 并发: 是同一个时刻只有一条指令在执行,其他指令没有再执行,但是由于CPU的时间片特别短,导致多个指令来回切换的时间间隔特别短,就好像是同一时间多条指令在执行。单核CPU与多核CPU都可以进…

渗透测试之漏洞 ms08-067 利用实验

实验背景 在安全服务项目中&#xff0c;需要对系统进行风险评估&#xff0c;其中风险评估的第一步:漏洞扫描即漏扫&#xff0c;在客户授权的前提下&#xff0c;对授权目标实施扫描并生成漏扫报告;在漏扫结束后&#xff0c;为了其准确性和完整性&#xff0c;还需对目标进行渗透…

FPGA FIFO IP核(3)- 仿真

仿真思路 如何在写入标志信号&#xff08;写入请求信号&#xff09;有效时将数据写入到FIFO中&#xff1f; 在调用模块代码中&#xff0c;pi_flag每四个时钟周期产生一个有效信号&#xff0c;即写请求信号。每次当pi_data检测到pi_flag信号有效时加1&#xff0c;从0~255循环变…