Element UI自动完成组件与表单校验冲突:如何解决表单校验失败的问题?

Element UI自动完成组件与表单校验冲突:如何解决表单校验失败的问题?

Element ui自动完成组件与表单校验冲突的解决方案

在使用Element UI的el-autocomplete组件时,经常会遇到表单校验失败的问题:即使用户已选择下拉选项,输入框显示正确值,表单仍提示未填写。本文分析此问题并提供解决方案。

问题描述:

表单使用el-autocomplete组件实现用户名选择,并用el-form-item和prop属性进行校验。el-autocomplete的select事件绑定了处理用户选择逻辑的函数。然而,用户选择后,表单校验仍失败,提示“请输入用户名”。

代码示例:

组件代码:

<el-form-item label="用户名" prop="username">   <el-autocomplete      :fetch-suggestions="querysearch"      class="usernameinput"      placeholder="选择或输入用户名"      v-model="selectuserinfo">   </el-autocomplete> </el-form-item>

校验规则:

rules: {   username: [{ required: true, message: '请输入用户名', trigger: 'blur' }],   password: [{ required: true, message: '请输入密码', trigger: 'blur' }] },

相关函数:

selectoption(params) {   console.log(this.selectuserinfo);   this.loginform.username = params.username;   this.loginform.password = atob(params.password); }, onblur() {   console.log('blur');   console.log(this.loginform.username, this.selectuserinfo);   this.loginform.username = this.selectuserinfo; },

问题分析与解决方法

问题根源在于直接赋值this.loginform.username = params.username可能破坏vue的响应式机制。Vue的响应式系统依赖数据变化触发视图更新和表单校验。直接修改对象属性,Vue无法追踪变化,导致表单校验无法更新。

解决方案:

  1. 确保loginform.username响应式: 如果loginform是普通JavaScript对象,直接赋值不会触发Vue响应式更新。使用Vue.set方法或对象展开运算符更新loginform.username,确保Vue追踪数据变化。

    selectoption(params) {   this.$set(this.loginform, 'username', params.username); // 使用 Vue.set   this.loginform.password = atob(params.password); }

    或:

    selectoption(params) {   this.loginForm = { ...this.loginForm, username: params.username }; // 对象展开运算符   this.loginForm.password = atob(params.password); }
  2. 检查trigger属性: trigger: ‘blur’仅在输入框失去焦点时触发校验。el-autocomplete的选择操作可能不会触发blur事件。尝试将trigger属性修改为’change’或同时使用’blur’和’change’,或根据实际情况选择合适的触发事件。

  3. 检查v-model绑定和loginform初始化: 确保v-model绑定数据正确,且loginform对象正确初始化为响应式对象。

通过以上方法,即可解决Element UI自动完成组件与表单校验冲突的问题,确保表单校验的准确性。

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