谷粒商城实战-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对接。

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

  • 14
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
根据引用中提供的信息,谷粒商城是一个B2C模式的电商平台,主要销售自营商品给客户。B2C模式指的是商对客的模式,即商家直接向消费者销售商品服务谷粒商城使用微服务架构,这是一种将应用程序拆分成独立且可独立开发、部署和扩展的小型服务的架构。引用还提到谷粒商城的技术涵盖微服务架构、分布式、全栈、集群、部署和自动化运维等方面。 因此,从前慢-谷粒商城篇章6主要讨论的可能是谷粒商城的技术方面,包括微服务架构、分布式、全栈、集群、部署和自动化运维等内容。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [从前慢-谷粒商城篇章1](https://blog.csdn.net/m0_67391121/article/details/125383572)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *3* [2020年谷粒商城md笔记](https://download.csdn.net/download/ZHUXIUQINGIT/12543161)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小手追梦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值