el-form验证报错TypeError: Cannot read properties of undefined (reading 'validate')
时间: 2023-12-14 19:34:38 浏览: 151
el-form验证报错TypeError: Cannot read properties of undefined (reading 'validate')通常是由于在Vue2工程中使用ElementUI表单(Form)的表单校验时出现的错误。这个错误通常是由于在表单校验之前没有正确地引入ElementUI的校验器validator导致的。解决这个问题的方法是在Vue组件中正确引入validator并在表单校验之前初始化它。
以下是一个解决el-form验证报错TypeError: Cannot read properties of undefined (reading 'validate')的例子:
```javascript
<template>
<el-form ref="form" :model="form" :rules="rules" 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="submitForm('form')">提交</el-button>
<el-button @click="resetForm('form')">重置</el-button>
</el-form-item>
</el-form>
</template>
<script>
import { Validator } from 'element-ui'
export default {
data() {
return {
form: {
username: '',
password: ''
},
rules: {
username: [
{ required: true, message: '请输入用户名', trigger: 'blur' }
],
password: [
{ required: true, message: '请输入密码', trigger: 'blur' }
]
}
}
},
methods: {
submitForm(formName) {
this.$refs[formName].validate(valid => {
if (valid) {
alert('验证通过')
} else {
alert('验证失败')
return false
}
})
},
resetForm(formName) {
this.$refs[formName].resetFields()
}
},
mounted() {
Validator.installDateTimeValidators(moment)
}
}
</script>
```
在这个例子中,我们首先从ElementUI中引入了Validator,然后在Vue组件的mounted钩子函数中初始化了Validator。这样就可以在表单校验之前正确地使用Validator了。
阅读全文