首页 web前端 js教程 Element UI自动完成组件与表单校验冲突:如何解决表单校验失败的问题?

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

Apr 04, 2025 pm 07:03 PM
vue 解决方法 red

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

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

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

问题描述:

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

代码示例:

组件代码:

<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自动完成组件与表单校验冲突的问题,确保表单校验的准确性。

以上是Element UI自动完成组件与表单校验冲突:如何解决表单校验失败的问题?的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

公司安全软件导致应用无法运行?如何排查和解决? 公司安全软件导致应用无法运行?如何排查和解决? Apr 19, 2025 pm 04:51 PM

公司安全软件导致部分应用无法正常运行的排查与解决方法许多公司为了保障内部网络安全,会部署安全软件。...

如何利用Redis缓存方案高效实现产品排行榜列表的需求? 如何利用Redis缓存方案高效实现产品排行榜列表的需求? Apr 19, 2025 pm 11:36 PM

Redis缓存方案如何实现产品排行榜列表的需求?在开发过程中,我们常常需要处理排行榜的需求,例如展示一个�...

Spring Boot中OAuth2Authorization对象Redis缓存失败怎么办? Spring Boot中OAuth2Authorization对象Redis缓存失败怎么办? Apr 19, 2025 pm 08:03 PM

SpringBoot中使用Redis缓存OAuth2Authorization对象在SpringBoot应用中,使用SpringSecurityOAuth2AuthorizationServer...

如何在Java中解析next-auth生成的JWT token并获取其中的信息? 如何在Java中解析next-auth生成的JWT token并获取其中的信息? Apr 19, 2025 pm 08:21 PM

在处理next-auth生成的JWT...

使用RedisTemplate进行批量查询时,为什么返回值会为空? 使用RedisTemplate进行批量查询时,为什么返回值会为空? Apr 19, 2025 pm 10:15 PM

使用RedisTemplate进行批量查询时为何返回值为空?在使用RedisTemplate进行批量查询操作时,可能会遇到返回的结果�...

在多节点环境下,如何确保Spring Boot的@Scheduled定时任务只在一个节点上执行? 在多节点环境下,如何确保Spring Boot的@Scheduled定时任务只在一个节点上执行? Apr 19, 2025 pm 10:57 PM

SpringBoot定时任务在多节点环境下的优化方案在开发Spring...

IDEA控制台日志打印空格问题如何解决? IDEA控制台日志打印空格问题如何解决? Apr 19, 2025 pm 09:57 PM

IDEA控制台日志打印空格问题如何解决?在使用IDEA进行开发时,很多开发者可能会遇到一个问题:控制台打印的�...

See all articles