vue + element-plus自定义表单验证(修改密码业务)的示例
写一个vue组件Password.vue
没有表单验证只有3个表单项
<template> <div> <el-form> <el-form-item label="旧密码"> <el-input></el-input> </el-form-item> <el-form-item label="新密码"> <el-input></el-input> </el-form-item> <el-form-item label="验证密码"> <el-input></el-input> </el-form-item> </el-form> </div> </template> <script setup> </script>
路由省略
给这个表单绑定一个对象
<template>
<div>
<el-form :="data.form">
<el-form-item label="旧密码" v-model="data.form.oldPassword">
<el-input ></el-input>
</el-form-item>
<el-form-item label="新密码" v-model="data.form.password">
<el-input></el-input>
</el-form-item>
<el-form-item label="验证密码" v-model="data.form.confirmPassword">
<el-input></el-input>
</el-form-item>
</el-form>
</div>
</template>
<script setup>
import {reactive} from "vue";
const data = reactive({
form: {
oldPassword: '',
password: '',
confirmPassword: ''
}
})
</script>给表单绑定规则注意表单项一定要有prop属性 属性值对应 data.rules里的属性
<template>
<div>
<el-form :model="data.form" :rules="data.rules">
<el-form-item label="旧密码" prop="oldPassword" >
<el-input v-model="data.form.oldPassword"></el-input>
</el-form-item>
<el-form-item label="新密码" prop="password">
<el-input v-model="data.form.password"></el-input>
</el-form-item>
<el-form-item label="验证密码" >
<el-input v-model="data.form.confirmPassword"></el-input>
</el-form-item>
</el-form>
</div>
</template>
<script setup>
import {reactive} from "vue";
const data = reactive({
form: {
oldPassword: '',
password: '',
confirmPassword: ''
}
,
rules: {
oldPassword: [
{ required: true, message: '请输入旧密码', trigger: 'blur' },
{ min: 6, max: 32, message: '长度在 6 到 32 个字符', trigger: 'blur' }
],
password: [
{ required: true, message: '请输入新密码', trigger: 'blur' },
{ min: 6, max: 32, message: '长度在 6 到 32个字符', trigger: 'blur' }
]
}
})
</script>添加自定义规则注意规则有优先级的
<template>
<div>
<el-form :model="data.form" :rules="data.rules">
<el-form-item label="旧密码" prop="oldPassword" >
<el-input v-model="data.form.oldPassword"></el-input>
</el-form-item>
<el-form-item label="新密码" prop="password">
<el-input v-model="data.form.password"></el-input>
</el-form-item>
<el-form-item label="验证密码" prop="confirmPassword">
<el-input v-model="data.form.confirmPassword"></el-input>
</el-form-item>
</el-form>
</div>
</template>
<script setup>
import {reactive} from "vue";
const validatePass1 = (rule, value, callback) => {
if (value === '') {
callback(new Error('请输入新密码'));
} else if (value !== '123') {
callback(new Error('旧密码错误'));
}else{
callback();
}
}
const validatePass2 = (rule, value, callback) => {
if (value === '') {
callback(new Error('请再次输入新密码'));
} else if (value !== data.form.password) {
callback(new Error('两次输入密码不一致!'));
} else {
callback();
}
}
const data = reactive({
form: {
oldPassword: '',
password: '',
confirmPassword: ''
}
,
rules: {
oldPassword: [
{ required: true, message: '请输入旧密码', trigger: 'blur' },
{validator: validatePass1, trigger: 'blur'}
],
password: [
{ required: true, message: '请输入新密码', trigger: 'blur' },
{ min: 6, max: 32, message: '长度在 6 到 32个字符', trigger: 'blur' }
],
confirmPassword: [
{ required: true, message: '请再次输入新密码', trigger: 'blur' },
{ validator: validatePass2, trigger: 'blur' }
]
}
})
</script>上一篇:Node.js 数据库 CRUD 项目示例详解(完美解决方案)
栏 目:JavaScript
本文标题:vue + element-plus自定义表单验证(修改密码业务)的示例
本文地址:https://fushidao.cc/wangluobiancheng/23745.html
您可能感兴趣的文章
- 02-04javascript解码揭秘,JavaScript核心原理及高效编码技巧之谜?
- 02-04javascript电子书涵盖哪些编程技巧与实战案例,适合哪些开发者阅读?
- 02-04JavaScript如何高效操作javascript二维数组的元素和方法选择?
- 02-04JavaScript全局变量如何影响代码的模块化和性能优化?
- 02-04javascript赋值
- 02-04a标签javascript如何正确运用和优化?探讨技巧与最佳实践疑问长尾标题
- 02-04javascript设计
- 02-04JavaScript翻译中的常见难点和高效策略探讨?
- 02-04javascript变量名
- 02-04JavaScript隐藏技巧,揭秘30种不为人知的隐藏方法之谜?
阅读排行
推荐教程
- 02-01如何选择最适合你的JavaScript视频教程?
- 04-23JavaScript Array实例方法flat的实现
- 04-23Vue3使用v-if指令进行条件渲染的实例代码
- 04-23THREE.JS使用TransformControls对模型拖拽的代码实例
- 07-21JavaScript判断数据类型的四种方式总结
- 07-21基于vue3与supabase系统认证机制详解
- 07-22JavaScript随机数生成各种技巧及实例代码
- 07-21JavaScript检查变量类型的常用方法
- 04-23vue3+ts项目搭建的实现示例
- 07-21JavaScript双问号操作符(??)的惊人用法总结大全



