vue + iview重置表单数据,清除表单部分校验信息

vue+iview表单,在添加和编辑,我们定义两个data

formData: {},
defaultForm: {
    sdId: '',
    parentSdId: '',
    targetCode: '',
    isDelect: 'false',
},

在我们需要清空表单数据和校验规则,

this.$refs.formData.resetFields();

并重置表单数据时,

this.formData = this.defaultForm;

发现defaultForm所有的属性值都变成了undefined,初始化表单数据失败,改为

this.formData = Object.assign({}, this.defaultForm);

 

如果大家有好的方法,希望提出来

 

========================================================

更新:

js的clone(克隆)问题,

1、如果克隆对象是基本类型,把一个值赋给另一个变量时,当那个变量的值改变的时候,另一个值不会受到影响

2、如果不是基本类型,变量的值会随着另一个值的改变而改变

参考博客:https://www.cnblogs.com/zouhao/p/7278117.html

 

===============================================================

1、有时候我们需要通过一键设置默认值,这时候表单校验不会主动触发,就会有校验信息遗留,所有要清除一键设置的部分表单校验信息,方法如下:

this.$refs.configForm.fields.forEach( (e) =>{
    if (e.prop == 'modelIterationTime' || e.prop == 'batchSize' || e.prop == 'learningRate' || e.prop == 'optimizeMethod') {
        e.resetField()
    }
})

2、有时候数据改变不会主动触发校验,需要我们手动去触发

this.$refs.formData.validateField('gpu');

 

  • 3
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值