el-form中的rules未生效的解决方法

yizhihongxing

当在使用element-uiel-form组件中配置rules进行表单验证时,有时会遇到rules未生效的问题。下面我们将介绍几种解决方法。

方法一:手动触发验证

当我们使用el-form组件配合rules进行表单校验时,需要在提交表单时调用validate方法触发表单校验。但有时由于各种原因,validate方法失效,可尝试手动触发验证。

<template>
  <el-form ref="formRef" :rules="rules" :model="form" label-width="80px">
    <el-form-item label="用户名" prop="username">
      <el-input v-model="form.username"></el-input>
    </el-form-item>
    <el-form-item label="密码" prop="password">
      <el-input type="password" v-model="form.password"></el-input>
    </el-form-item>
    <el-form-item>
      <el-button type="primary" @click="handleSubmit">提交</el-button>
    </el-form-item>
  </el-form>
</template>
<script>
export default {
  data() {
    return {
      form: {
        username: '',
        password: ''
      },
      rules: {
        username: [
          { required: true, message: '请输入用户名', trigger: 'blur' }
        ],
        password: [
          { required: true, message: '请输入密码', trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    handleSubmit() {
      this.$refs.formRef.validate((valid) => {
        if (valid) {
          console.log('校验通过')
          // 提交表单操作
        } else {
          console.log('校验失败')
        }
      })
    },
  }
}
</script>

如果以上代码在提交时未触发表单校验,可尝试在handleSUbmit方法中使用this.$refs.formRef.validate()手动触发表单校验。这样就能保证表单校验的有效性。

方法二:修改rules的prop属性的大小写

在使用el-form组件时,该组件会自动将rulesprop属性转换为小写,而model中属性为大小写敏感。如果在rules中的prop属性在大小写方面与model不一致,则会导致表单校验失败。例如:

<template>
  <el-form :model="form" :rules="rules" ref="formRef" label-width="80px">
    <el-form-item label="姓名" prop="name">
      <el-input v-model="form.name"></el-input>
    </el-form-item>
    <el-form-item label="手机号" prop="phoneNum">
      <el-input v-model="form.phoneNum"></el-input>
    </el-form-item>
    <el-form-item>
      <el-button type="primary" @click="handleSubmit">提交</el-button>
    </el-form-item>
  </el-form>
</template>
<script>
export default {
  data() {
    return {
      form: {
        name: '',
        phoneNum: ''
      },
      rules: {
        name: [
          { required: true, message: '请输入姓名', trigger: 'blur' }
        ],
        phoneNum: [
          { required: true, message: '请输入手机号', trigger: 'blur' },
          { pattern: /^1[3456789]\d{9}$/, message: '手机号格式不正确', trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    handleSubmit() {
      this.$refs.formRef.validate(valid => {
        if (valid) {
          console.log('校验通过')
          // 提交表单操作
        } else {
          console.log('校验失败')
        }
      })
    }
  }
}
</script>

以上代码校验phoneNum时校验失败,是因为rules中的prop属性为phoneNum,而model中的属性为phoneNum,大小写存在差异。我们只需将其改为一致即可。

<template>
  <el-form :model="form" :rules="rules" ref="formRef" label-width="80px">
    <el-form-item label="姓名" prop="name">
      <el-input v-model="form.name"></el-input>
    </el-form-item>
    <el-form-item label="手机号" prop="phonenum">
      <el-input v-model="form.phonenum"></el-input>
    </el-form-item>
    <el-form-item>
      <el-button type="primary" @click="handleSubmit">提交</el-button>
    </el-form-item>
  </el-form>
</template>
<script>
export default {
  data() {
    return {
      form: {
        name: '',
        phonenum: ''
      },
      rules: {
        name: [
          { required: true, message: '请输入姓名', trigger: 'blur' }
        ],
        phonenum: [
          { required: true, message: '请输入手机号', trigger: 'blur' },
          { pattern: /^1[3456789]\d{9}$/, message: '手机号格式不正确', trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    handleSubmit() {
      this.$refs.formRef.validate(valid => {
        if (valid) {
          console.log('校验通过')
          // 提交表单操作
        } else {
          console.log('校验失败')
        }
      })
    }
  }
}
</script>

通过以上两种方法,应该能够解决el-form组件中的rules未生效问题。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:el-form中的rules未生效的解决方法 - Python技术站

(2)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • ES6中异步对象Promise用法详解

    ES6中异步对象Promise用法详解 什么是Promise Promise是 ES6 引入,用于异步编程的一种解决方案。简单来说,Promise就是一个代表了异步操作的对象,该对象可以用来获取异步操作结果。Promise 对象在异步操作的初始阶段就返回给调用方一个代表结果的“承诺”,以后当异步操作完成时,Promise 会根据异步操作的结果,改变自己的状态…

    Vue 2023年5月28日
    00
  • 浅谈vue生命周期共有几个阶段?分别是什么?

    当我们使用Vue.js开发应用时,组件会自动地创建、渲染、更新和销毁,这正是Vue.js的生命周期。Vue.js生命周期可以帮助我们了解整个Vue组件的运行过程,这对于开发和调试Vue应用程序非常有帮助。 Vue.js生命周期共有8个阶段,分别是: beforeCreate:组件实例被创建之初,组件属性计算之前,这个阶段的生命周期函数无法访问到组件的属性和方…

    Vue 2023年5月28日
    00
  • 简单聊一聊axios配置请求头content-type

    当使用axios发送HTTP请求时,你可以在请求中添加headers头部来指定Content-Type类型。默认情况下,Content-Type类型为application/json。这意味着在发送axios请求时,如果我们的请求需要使用不同的Content-Type设置,我们需要进行额外的配置。 下面是一份通用的axios请求配置,可以让我们设置请求头的C…

    Vue 2023年5月28日
    00
  • vue中get方法\post方法如何传递数组参数详解

    Vue中get方法/post方法如何传递数组参数详解 在Vue中,我们经常需要通过HTTP请求获取或修改数据,并且有时需要通过数组的方式传递参数。本文将详细讲解Vue中如何使用get方法和post方法传递数组参数。 使用get方法传递数组参数 Get方法通常用于获取数据。如果我们需要传递数组参数,我们可以使用Vue的$http.get方法,并将参数以字符串形…

    Vue 2023年5月29日
    00
  • VUEJS实战之构建基础并渲染出列表(1)

    “VUEJS实战之构建基础并渲染出列表(1)”是一个Vue.js实战教程,主要讲解如何使用Vue.js构建基础并渲染出列表。下面是该教程的完整攻略: 一、环境搭建 首先,我们需要在本地搭建Vue.js的开发环境。具体步骤如下: 安装Node.js和npm; 使用npm安装Vue.js:npm install vue; 在HTML文件中引入Vue.js:&lt…

    Vue 2023年5月27日
    00
  • Vue自定义指令使用方法详解

    Vue自定义指令使用方法详解 什么是自定义指令 Vue.js 自带一些指令,比如 v-if、v-for 等,用于操作元素的属性、文本内容等。而自定义指令,就是允许我们自定义一些指令,实现一些 Vue.js 自带指令不具备的操作。 Vue.js 的自定义指令是通过 directive 方法来实现的,语法如下: // 全局定义 Vue.directive(‘指令…

    Vue 2023年5月27日
    00
  • vue 使用post/get 下载导出文件操作

    要在Vue中使用POST/GET下载导出文件,我们可以使用Axios库来发送异步请求并处理响应。以下是完整的攻略。 创建后台API 首先,我们需要在后台创建可以导出文件的API。通常情况下,我们会在服务器上为此目的创建一个专用的控制器。 对于此示例,我们将创建一个名为export的GET请求,并将文件的URL作为响应发送回到客户端。请注意,此示例代码仅用于参…

    Vue 2023年5月27日
    00
  • 解决vue单页面应用打包后相对路径、绝对路径相关问题

    解决Vue单页面应用打包后相对路径、绝对路径相关问题是一个常见的问题,这里提供一个完整攻略,以帮助开发者快速解决问题。 问题描述 在开发Vue单页面应用时,需要引入各种资源文件,如CSS样式文件、JS脚本文件、图片资源文件等等。这些文件在开发时,都是通过相对路径或绝对路径引入的。但是,在打包完成后,这些资源文件会被压缩和合并,导致相对路径或绝对路径失效,进而…

    Vue 2023年5月28日
    00
合作推广
合作推广
分享本页
返回顶部