:ref="dataForm" // 提交表单时进行校验
:rules="rules" // return 下的校验规则
:model="userForm" // 绑定表单的值
- <el-form
- ref="dataForm" // 必写属性值
- :rules="rules" // 必写属性值
- :model="userForm" // 必写属性值
- label-position="left"
- label-width="100px"
- >
- <el-row>
- <el-col :span="12">
- <el-form-item
- label="充值金额"
- prop="amount" // 必写属性值
- >
- <el-input
- v-model="userForm.amount" // 必写属性值
- placeholder="请输入充值金额"
- >el-input>
- el-form-item>
- el-col>
- el-row>
- el-form>
- <div slot="footer" class="dialog-footer" align="center">
- <el-button @click="dialogFormVisible = false">返回el-button>
- <el-button type="primary" @click="Recharge()" >
- 提交
- el-button>
- div>
点击提交时,会先对表单的值进行校验判断,校验通过后,再进行后续操作。
- Recharge() {
- this.$refs['dataForm'].validate((valid) => {
- if (valid) {
- // 校验通过、调充值接口的逻辑操作
- }
- })
el-form-item 里面使用 prop 属性绑定规则
... ...
required:显示输入框为选填或必填项;
message:提示信息;pattern:正则表达式;
trigger:触发事件 => 一般blur用于input、chang用于select,picker等;
- data() {
- return {
- rules: {
- amount: [
- { required: true, message: '充值金额不能为空', trigger: 'blur' },
- {
- pattern: /^\d+(\.\d{1,1})?$/,
- message: '金额为数字类型且最多保留1位小数',
- trigger: 'blur',
- },
- ],
- },
- }
- },
el-input 里面使用 v-model 绑定表单值
- data() {
- return {
- userForm: {
- amount: '',
- },
- }
- },
校验未通过,关闭弹窗再打开还存在的问题:
this.dialogFormVisible = true this.$nextTick(() => { this.$refs['dataForm'].clearValidate() })