Element UI表单动态校验:如何解决数据回显延迟导致的校验异常?

element ui表单动态校验与数据回显延迟导致的校验问题

在使用 Element UI 的 el-form 组件进行表单动态校验时,如果后端接口返回数据存在延迟,可能会导致校验规则出现异常。本文将针对一个具体的案例,分析这种问题产生的原因并提供解决方案。

问题描述:

用户在使用 el-form 表单时,遇到了一个动态校验问题。表单项“座数”的校验规则依赖于后端接口返回的 isCutomadded、showEstAdressbui 和 propertyInfo.propertyCategory 等数据。由于接口返回数据较慢,导致 required 属性的值在校验过程中发生变化:初始值为 true (显示必填星号),随后变为 false (必填星号消失),但必填的文案仍然保留。

代码片段:

<el-form-item label="座數" prop="buildingNameWithCulture" :rules="propertyInfo.propertyCategory == 1 && !isCutomadded && showEstAdressbui && editNewDataRule ? rules.buildingNameWithCulture : [{ required: false }]"> </el-form-item>

问题分析:

上述代码中,el-form-item 的 :rules 属性动态绑定了一个校验规则数组。当 propertyInfo.propertyCategory == 1 && !isCutomadded && showEstAdressbui && editNewDataRule 条件为真时,应用 rules.buildingNameWithCulture 中定义的校验规则;否则,应用 { required: false },表示该字段非必填。由于接口返回 isCutomadded 和 showEstAdressbui 数据延迟,导致在校验规则计算完成前,required 属性已经先进行了初始判断,造成必填星号的短暂显示,之后又根据接口返回数据更新为非必填,但文案因为dom更新机制并未及时更新。

解决方案:

问题关键在于接口数据返回的延迟导致了校验规则的短暂不一致。解决方法是,在数据未完全加载完成之前,不要进行校验。可以使用一个变量来控制校验规则的应用时机,只有在数据加载完成后再进行校验。或者,直接使用空数组 [] 来代替 { required: false },达到禁用校验的目的。

代码示例(修改后的代码,仅供参考,具体实现需根据实际情况调整):

//  假设 dataReady 为一个布尔变量,表示数据是否加载完成 <el-form-item label="座數" prop="buildingNameWithCulture" :rules="dataReady && (propertyInfo.propertyCategory == 1 && !isCutomadded && showEstAdressbui && editNewDataRule) ? rules.buildingNameWithCulture : []"> </el-form-item>

通过上述方法,可以有效避免由于数据回显延迟导致的表单校验问题。 记住,在数据加载完成后再启用校验规则,或者使用空数组 [] 来直接禁用校验是解决这类问题的关键。

© 版权声明
THE END
喜欢就支持一下吧
点赞9 分享