首页 > 其他分享 >day05-功能实现04

day05-功能实现04

时间:2023-03-10 23:22:04浏览次数:70  
标签:功能 04 校验 day05 表单 添加 blur message 输入

功能实现04

后端:https://github.com/liyuelian/furniture-back-end.git

前端:https://github.com/liyuelian/furniture-front-end.git

9.功能09-添加家居表单前端校验

9.1需求分析

在添加家居表单时,如果添加的数据不符合格式,应该拒绝添加,并给出提示

9.2思路分析

  1. 完成前端代码,使用Element Plus的表单rules验证即可
  2. 参考ElementPlus的表单验证文档

9.3代码实现

(1)数据池添加校验规则

...
//修改数据池,添加表单的校验规则
data() {
  return {
    ...
    //定义添加表单的校验规则
    rules: {
      name: [//这里我们可以添加多个针对name属性的规则校验
        {required: true, message: "请输入家居名", tigger: "blur"}
      ],
      maker: [
        {required: true, message: "请输入厂商", tigger: "blur"}
      ],
      price: [
        {required: true, message: "请输入价格", tigger: "blur"},
        //使用正则表达式对输入的数字进行处理
        {pattern: /^([1-9]\d*|0)(\.\d+)?$/, message: "请输入数字", tigger: "blur"}
      ],
      sales: [
        {required: true, message: "请输入销量", tigger: "blur"},
        //使用正则表达式对输入的数字进行处理
        {pattern: /^([1-9]\d*|0)$/, message: "请输入数字", tigger: "blur"}
      ],
      stock: [
        {required: true, message: "请输入库存", tigger: "blur"},
        //使用正则表达式对输入的数字进行处理
        {pattern: /^([1-9]\d*|0)$/, message: "请输入数字", tigger: "blur"}
      ]
    }
  }
}
...

(2)指定将创建的规则应用到form表单,注意名称要对应

image-20230310212556639

(3)修改save方法,当表单验证不通过时,不提交表单

...
save() {//将填写的表单数据发送给后端
  //修改和添加走的同一个方法
  if (this.form.id) {//如果为修改业务,当前的id存在,表示真
    ...
  } else {//添加业务
    //表单验证是否通过
    this.$refs['form'].validate((valid) => {
      //valid就是表单校验结果
      if (valid) {//如果校验通过
        //第一个参数为url,第二个参数是请求携带的数据
        request.post("/api/save", this.form).then(res => {
          console.log("res-", res)
          this.dialogVisible = false;//隐藏表单
          //调用list方法,刷新页面显示的数据
          this.list();
          this.$message({
                type: "success",
                message: "添加成功"
           })
        })
      } else {//校验没有通过
        this.$message({
          type: "error",
          message: "验证失败,不提交"
        })
        return false;//放弃提交
      }
    })
  }
},
...

(4)测试

image-20230310213446769

10.功能10-添加家居表单后端校验

10.1需求分析

  1. 前端校验了,后端仍然需要对数据进行校验。因为要防止类似postman的软件绕过前端验证直接发送请求。
  2. 当后端校验没有通过时,给前端表单出现灰色提示,后台不真正入库数据

10.2思路分析

  1. 后端使用 JSR303数据校验,引入hibernate-validator.jar
  2. 前端使用ElementPlus进行数据绑定,并显示错误信息

10.2代码实现

(1)修改pom.xml文件,引入 JSR303 数据校验支持

<!--引入JSR303数据校验支持-->
<dependency>
  <groupId>org.hibernate</groupId>
  <artifactId>hibernate-validator</artifactId>
  <version>6.1.0.Final</version>
</dependency>

(2)修改Furn.java实体类

public class Furn {
    private Integer id;

    @NotEmpty(message = "请输入家居名")
    private String name;

    @NotEmpty(message = "请输入厂商名")
    private String maker;

    @NotNull(message = "请输入价格")
    @Range(min = 0,message = "价格不能小于0")
    private BigDecimal price;

    @NotNull(message = "请输入销量")
    @Range(min = 0,message = "销量不能小于0")
    private Integer sales;

    @NotNull(message = "请输入库存")
    @Range(min = 0,message = "库存不能小于0")
    private Integer stock;

    ...
}

(3)修改FurnController.java的save()方法,添加校验

/**
 * 1.响应客户端添加家居的请求
 * 2.@RequestBody 注解将客户端提交的json数据封装成 Javabean 对象。
 * 3.@ResponseBody 服务器返回的数据是按照json来返回的(底层是按照 http协议进行协商)
 * 4.@Validated 对接收的信息进行校验
 * 5.Errors用来接收校验可能出现的错误信息
 *
 * @param furn
 * @return
 */
@ResponseBody
@PostMapping("/save")
public Msg save(@Validated @RequestBody Furn furn, Errors errors) {
    Map<Object, Object> map = new HashMap<>();

    List<FieldError> fieldErrors = errors.getFieldErrors();

    for (FieldError fieldError : fieldErrors) {
        map.put(fieldError.getField(), fieldError.getDefaultMessage());
    }

    if (map.isEmpty()) {//说明后端校验没有出现错误
        furnService.save(furn);
        //如果没有出现异常,就返回成功
        return Msg.success();
    } else {
        //校验失败,将校验错误信息封装到Msg对象,并返回
        return Msg.fail().add("errorMsg", map);
    }
}

(4)使用postman进行测试

image-20230310223403587

可以看到返回了错误信息:

image-20230310223505003

(5)在HomeView.vue中显示服务器校验返回的提示信息(略)

11.小结

说明:前后端框架分离,前端Vue,后端框架SSM

  1. 前端框架Vue
  2. 后端框架SSM
  3. 数据库Mysql
  4. 项目的依赖管理Maven
  5. 分页pageHelper
  6. 逆向工程MyBatis Generator

-前端框架Vue

  1. 使用了ElementPlus来展示数据
  2. 使用Axios对象来请求数据/接口

-后端框架SSM

  1. 使用经典的三层结构
  2. 使用MyBatis Generator和MyBatis pageHelper

标签:功能,04,校验,day05,表单,添加,blur,message,输入
From: https://www.cnblogs.com/liyuelian/p/17204974.html

相关文章

  • linux基础day04:bash初识02
    bash初识02shell的基本用法命令[-options]argumentscommand-选项参数(动作对象)目录名/路径命令(必须在顶格)格式:#命令空格[选项]空格[......
  • 10.优化登陆达到维持登陆和免密登陆功能
    在utils目录下增加了memoryUtils.js和storageUtils.js文件需要安装store.js —>npm installstore【版本:2.0.12】 查看local存储信息,打开开发者工具memor......
  • Ubuntu 20.04 分区方案
     说明:固态硬盘是/dev/nvme0n1,分为4个分区:swap分区:32G,因为我的内存是32G(主分区)/usr:很多应用程序和文件都放在这个目录下,类似于windows下的programfiles目录,我分......
  • 04 文件的高级操作:控制文件指针的移动
    """@作者:egon老湿@微信:18611453110@专栏:https://zhuanlan.zhihu.com/c_1189883314197168128"""#指针移动的单位都是以bytes/字节为单位#只有一种情况特殊:#t......
  • 如何利用多功能智慧杆建设森林防火监测预警网?
    近年来,我国森林面积稳步增长,生态空间质量稳中向好,森林碳汇能力稳步提升,“绿水青山就是金山银山”的发展理念得到有效贯彻。但随着森林面积的不断扩大,森林火灾的风险也随之......
  • 树莓派烧录ubuntu18.04.5
    准备工作:树莓派4B一个,内存不小于16G的TF卡一个,树莓派的充电线一个,笔记本电脑一台,网线一根,读卡器一个1、格式化TF卡建议选择16G以上的TF卡,下载格式化工具选择要格式化的T......
  • dolphinscheduler补数功能使用记录
    1.背景有一批小时级的任务挂了,需要重新补数,要补2.1-2.10号连续10天的所有小时任务2.操作笔记ds补数目前是选定日期区间内每天启动一个流程实例,小时级的任务就不太好补了......
  • 秒杀功能实现
    商品秒杀功能实现利用celery模块异步提交秒杀任务逻辑:1.前端发送秒杀请求,后端收到请求后异步执行立即返回前端异步执行任务的id​2.前端设置轮询每2秒拿......
  • Ubuntu 20.04 双网卡绑定bond 主备模式
     一、active-backup-主备模式一个网卡处于活动状态,另一个处于备份状态,所有流量都在主链路上处理,当活动网卡down掉时,启用备份网卡。 1、实验环境VMware虚拟机,系统Ubu......
  • ubuntu20.04 单机运行kafka和zookeeper
    参考文章:Ubuntu安装单机模式kafka......