ElementUI中 el-form 表单面向 多层嵌套数据(实体类或数组) 的校验 validate 异常解决

感谢这篇文章的提示,按照ElementUI官网,对于单层或者两层结构的数据 , el-form 表单很容易地在el-form-item的prop属性绑定对应model中的字段,即可完成校验 validate 。但是对于多层嵌套数据(实体类或数组),诸如以下结构:

data1: {
    field11: '',
    field12: '',
    data2: {
        field21: '',
        field22: '',
        data4: {
            field41: '',
            field42: '',
        }
    },
    data3: {
        field31: '',
        field32: '',
    }
}

虽然对于el-form-item中组件绑定v-model(如data1.data2.data4.field42),可以对这个数据项进行修改,但是该el-form-item的prop属性值如何写,如果是field42或者是data1.data2.data4.field42,都会出现异常 :

Error in mounted hook: "Error: please transfer a valid prop path to form item!"

el-form无法通过prop值找到对应的字段进行校验,因此受开头那篇文章的启发,可以在已有的el-form的内部,嵌套一个el-form,其mode绑定data1.data2,el-form-item的prop可以直接绑定field42,组件的v-mode绑定data1.data2.data4.field42,最终可以完成校验,可以在JavaScript嵌套的使用if-else进行校验,比如:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值