table中添加和编辑功能共用一个form表单时可能出现的问题

在Vue中,如果表单的添加和编辑功能使用同一套验证规则,可能导致在编辑时出现错误提示,例如用户名必须唯一的验证。当仅修改非用户名字段时,不应触发该验证。解决方案包括:1)定义用于验证的数据;2)通过Ajax获取所需数据并解构;3)定制验证函数以区分编辑和添加操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

 如上图所示两个按钮用的同一个弹出框,这里表单我是单独封装的一个组件

问题: 例如要验证用户名不能重复,当你在表单验证时,编辑和添加是共用一套表单验证规则,而在添加时: 约定所有的已有的用户名是不能使用的, 但是当你做编辑功能时,你只是改了别的数据,没改用户名,这种情况应该是允许的,但是你会发现用户名那一栏就会提示你的用户名必须唯一

下面我们说说解决方案: 

1.定义一个用来接收你验证表单需要用到的数据

 data() {
    return {
      // 用来接收验证表单数据的数组
      originList: []
    }
  }

 2.发送ajax请求数据把自己想要的数据解构出来

this.originList = res.data.depts.map(item => {
        return { id: item.id, code: item.code, name: item.name, pid: item.pid }
      })

3.定义验证函数(认真看,关键点)

const existCodeList = (rule, value, callback) => {
  // 1. 把从父组件传过来的表单验证需要的变量解构出来
  const { originList, id, isEdit } = this
  // 2. 判断用户点击的是否是编辑按钮
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值