vue 表单验证并提交

一、常用验证方式

vue 中表单字段验证的写法和方式有多种,常用的验证方式有3种:

1.data 中验证

表单内容:

   
   
  • 1
<!-- 表单 -->
<el-form ref="rulesForm" :rules="formRules" :model="rulesForm" label-width="200px">
    <el-form-item label="用户名称:" prop="userName">
       <el-input v-model="rulesForm.userName" style="width:300px" maxlength="50"/>
    </el-form-item>
</el-form>

   
   
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

:代表这是一个表单
-> ref:表单被引用时的名称,标识
-> rules:表单验证规则
-> model:表单数据对象
-> label-width:表单域标签的宽度,作为 Form 直接子元素的 form-item 会继承该值
-> :表单中的每一项子元素
-> label:标签文本
-> prop:表单域 model 字段,在使用 validate、resetFields 方法的情况下,该属性是必填的
:输入框
-> v-model:绑定的表单数据对象属性
-> style:行内样式
-> maxlength:最大字符长度限制

data 数据:

data() {
    return {
        // 省略别的数据定义
        ...
        // 表单验证
        formRules: {
            userName: [
                {required: true,message: "请输入用户名称",trigger: "blur"}
            ]
        }
    }
}

   
   
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12

formRules:与上文 ‘表单内容’ 中 表单的 :rules 属性值相同
userName:与上文 ‘表单内容’ 中 表单子元素的 prop 属性值相同
验证内容是:必填,失去焦点时验证,如果为空,提示信息为 ‘请输入用户名称’。
可以加多个验证规则:

rules: {
        age: [
          // 必填
          { required: true, message: '请输入年龄', trigger: 'blur' },
         // 必须是数字
          { validator: isNum, trigger: 'blur' }
        ],

   
   
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

2.行内验证

	表单内容:

   
   
  • 1
	<!-- 表单 -->
<el-form ref="rulesForm" :rules="formRules" :model="rulesForm" label-width="200px">
    <el-form-item label="银行名称:" prop="accountName" :rules="[{required:true,message:'请输入银行名称',trigger:'blur'}]">
        <el-input v-model="rulesForm.accountName" style="width:300px" maxlength="50"/>
    </el-form-item>
</el-form>

   
   
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

-> rules:和第一种方式表现的效果一致,只是写法不一样。
data 数据没有内容

3.引入外部定义的规则

表单内容

<!-- 表单 -->
<el-form ref="rulesForm" :rules="formRules" :model="rulesForm" label-width="200px">
    <el-form-item label="银行卡号:" prop="accountNumber">
       <el-input v-model="rulesForm.accountNumber" style="width:300px" maxlength="19"/>
    </el-form-item>
</el-form>

   
   
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

表单内容与第一种方式写法一致。
script 内容

<script>
// 引入了外部的验证规则
import { validateAccountNumber } from "@/utils/validate";

// 判断银行卡账户是否正确
const validatorAccountNumber = (rule, value, callback) => {
if (!value) {
return callback(new Error(“请输入账户信息”));
} else {
if (validateAccountNumber(value)) {
callback();
} else {
return callback(new Error(‘账号格式不正确’))
}
}
};

export default {
data() {
return {
// 省略别的数据定义

        // 表单验证
        formRules: {
            accountNumber: [
                {required: true,validator: validatorAccountNumber,trigger: "blur"}
            ]
        }
    }
}

}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32

import:先引入了外部的验证规则
const:定义一个规则常量,常量名可变, ‘= (rule, value, callback) => {}’ 为固定格式,value 入参为验证的字段值
formRules -> accountNumber:表单验证中使用 validator 指定自定义校验规则常量名称
validate.js

二、表单提交时验证

1.表单的提交按钮

<!-- 表单 -->
<el-form ref="rulesForm" :rules="formRules" :model="rulesForm" label-width="200px">
    <el-form-item>
        <el-button type="primary" @click="onSubmit('rulesForm')">保存</el-button>
        <el-button @click="cancel">取消</el-button>
    </el-form-item>
</el-form>

 
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

:按钮
-> type:按钮类型
-> @click:按钮点击时触发的事件,这里注意方法的入参为 ‘rulesForm’,这里要与 表单的 ref 属性值一致。

2.ethods 方法



 
 
  • 1

methods: {
// 保存
onSubmit(formName) {
this.$refs[formName].validate(valid => {
if (valid) {
console.log(“success submit!!”);
}else{
console.log(“error submit!!”);
}
}
},
// 取消
cancel() {
}
}

his.$refs[formName].validate:formName 就是传入的 'rulesForm',与 <el-form> 表单的 rel 属性值一致,这样就指定好需要验证的表单了。

另外附:
validator.js

/是否合法IP地址/
export function validateIP(rule, value,callback) {
if(value==’’||valueundefined||valuenull){
callback();
}else {
const reg = /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5]).(\d{1,2}|1\d\d|2[0-4]\d|25[0-5]).(\d{1,2}|1\d\d|2[0-4]\d|25[0-5]).(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/;
if ((!reg.test(value)) && value != ‘’) {
callback(new Error(‘请输入正确的IP地址’));
} else {
callback();
}
}
}

/* 是否手机号码或者固话*/
export function validatePhoneTwo(rule, value, callback) {
const reg = /^((0\d{2,3}-\d{7,8})|(1[34578]\d{9}))KaTeX parse error: Expected '}', got '&' at position 119: …g.test(value)) &̲amp;&amp; value…/;
if(value==’’||valueundefined||valuenull){
callback();
}else {
if ((!reg.test(value)) && value != ‘’) {
callback(new Error(‘请输入正确的电话号码’));
} else {
callback();
}
}
}
/* 是否身份证号码*/
export function validateIdNo(rule, value,callback) {
const reg = /(\d{15}$)|(^\d{18}$)|(\d{17}(\d|X|x)KaTeX parse error: Expected '}', got '&' at position 106: …g.test(value)) &̲amp;&amp; value…/;
if(value==’’||valueundefined||valuenull){
callback();
}else{
if (!reg.test(value)){
callback(new Error(‘请输入正确的邮箱地址’));
} else {
callback();
}
}
}
/* 合法uri*/
export function validateURL(textval) {
const urlregex = /^(https?|ftp)😕/([a-zA-Z0-9.-]+(:[a-zA-Z0-9.&%KaTeX parse error: Can't use function '\.' in math mode at position 54: …}|[1-9][0-9]?)(\̲.̲(25[0-5]|2[0-4]…|[a-zA-Z0-9.,?’\+&%KaTeX parse error: Expected 'EOF', got '#' at position 1: #̲=~_-]+))*/;
return urlregex.test(textval);
}

/验证内容是否英文数字以及下划线/
export function isPassword(rule, value, callback) {
const reg =/1+$/;
if(value==’’||valueundefined||valuenull){
callback();
} else {
if (!reg.test(value)){
callback(new Error(‘密码仅由英文字母,数字以及下划线组成’));
} else {
callback();
}
}
}

/自动检验数值的范围/
export function checkMax20000(rule, value, callback) {
if (value == ‘’ || value == undefined || value == null) {
callback();
} else if (!Number(value)) {
callback(new Error(‘请输入[1,20000]之间的数字’));
} else if (value < 1 || value > 20000) {
callback(new Error(‘请输入[1,20000]之间的数字’));
} else {
callback();
}
}

//验证数字输入框最大数值,32767
export function checkMaxVal(rule, value,callback) {
if (value < 0 || value > 32767) {
callback(new Error(‘请输入[0,32767]之间的数字’));
} else {
callback();
}
}
//验证是否1-99之间
export function isOneToNinetyNine(rule, value, callback) {
if (!value) {
return callback(new Error(‘输入不可以为空’));
}
setTimeout(() => {
if (!Number(value)) {
callback(new Error(‘请输入正整数’));
} else {
const re = /2[0-9]{0,1}$/;
const rsCheck = re.test(value);
if (!rsCheck) {
callback(new Error(‘请输入正整数,值为【1,99】’));
} else {
callback();
}
}
}, 0);
}

// 验证是否整数
export function isInteger(rule, value, callback) {
if (!value) {
return callback(new Error(‘输入不可以为空’));
}
setTimeout(() => {
if (!Number(value)) {
callback(new Error(‘请输入正整数’));
} else {
const re = /3[1-9][0-9]KaTeX parse error: Expected 'EOF', got '}' at position 150: …); } }̲ }, 0); } // …/;
const rsCheck = re.test(value);
if (!rsCheck) {
callback(new Error(‘请输入正整数’));
} else {
callback();
}
}
}, 1000);
}

// 验证是否是[0-1]的小数
export function isDecimal(rule, value, callback) {
if (!value) {
return callback(new Error(‘输入不可以为空’));
}
setTimeout(() => {
if (!Number(value)) {
callback(new Error(‘请输入[0,1]之间的数字’));
} else {
if (value < 0 || value > 1) {
callback(new Error(‘请输入[0,1]之间的数字’));
} else {
callback();
}
}
}, 100);
}

// 验证是否是[1-10]的小数,即不可以等于0
export function isBtnOneToTen(rule, value, callback) {
if (typeof value == ‘undefined’) {
return callback(new Error(‘输入不可以为空’));
}
setTimeout(() => {
if (!Number(value)) {
callback(new Error(‘请输入正整数,值为[1,10]’));
} else {
if (!(value == ‘1’ || value == ‘2’ || value == ‘3’ || value == ‘4’ || value == ‘5’ || value == ‘6’ || value == ‘7’ || value == ‘8’ || value == ‘9’ || value == ‘10’)) {
callback(new Error(‘请输入正整数,值为[1,10]’));
} else {
callback();
}
}
}, 100);
}
// 验证是否是[1-100]的小数,即不可以等于0
export function isBtnOneToHundred(rule, value, callback) {
if (!value) {
return callback(new Error(‘输入不可以为空’));
}
setTimeout(() => {
if (!Number(value)) {
callback(new Error(‘请输入整数,值为[1,100]’));
} else {
if (value < 1 || value > 100) {
callback(new Error(‘请输入整数,值为[1,100]’));
} else {
callback();
}
}
}, 100);
}
// 验证是否是[0-100]的小数
export function isBtnZeroToHundred(rule, value, callback) {
if (!value) {
return callback(new Error(‘输入不可以为空’));
}
setTimeout(() => {
if (!Number(value)) {
callback(new Error(‘请输入[1,100]之间的数字’));
} else {
if (value < 0 || value > 100) {
callback(new Error(‘请输入[1,100]之间的数字’));
} else {
callback();
}
}
}, 100);
}

// 验证端口是否在[0,65535]之间
export function isPort(rule, value, callback) {
if (!value) {
return callback(new Error(‘输入不可以为空’));
}
setTimeout(() => {
if (value == ‘’ || typeof(value) == undefined) {
callback(new Error(‘请输入端口值’));
} else {
const re = /^([0-9]|[1-9]\d|[1-9]\d{2}|[1-9]\d{3}|[1-5]\d{4}|6[0-4]\d{3}|65[0-4]\d{2}|655[0-2]\d|6553[0-5])KaTeX parse error: Expected 'EOF', got '}' at position 163: …); } }̲ }, 100); } /…/;
const rsCheck = re.test(value);
if (!rsCheck) {
callback(new Error(‘请输入在[0-65535]之间的端口值’));
} else {
callback();
}
}
}, 100);
}

/* 小写字母*/
export function validateLowerCase(str) {
const reg = /4+KaTeX parse error: Expected 'EOF', got '}' at position 28: …reg.test(str); }̲ /*保留2为小数*/ exp…/;
// return reg.test(str);
// }

/* 大写字母*/
export function validateUpperCase(str) {
const reg = /5+$/;
return reg.test(str);
}

/* 大小写字母*/
export function validatAlphabets(str) {
const reg = /6+$/;
return reg.test(str);
}

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65
  • 66
  • 67
  • 68
  • 69
  • 70
  • 71
  • 72
  • 73
  • 74
  • 75
  • 76
  • 77
  • 78
  • 79
  • 80
  • 81
  • 82
  • 83
  • 84
  • 85
  • 86
  • 87
  • 88
  • 89
  • 90
  • 91
  • 92
  • 93
  • 94
  • 95
  • 96
  • 97
  • 98
  • 99
  • 100
  • 101
  • 102
  • 103
  • 104
  • 105
  • 106
  • 107
  • 108
  • 109
  • 110
  • 111
  • 112
  • 113
  • 114
  • 115
  • 116
  • 117
  • 118
  • 119
  • 120
  • 121
  • 122
  • 123
  • 124
  • 125
  • 126
  • 127
  • 128
  • 129
  • 130
  • 131
  • 132
  • 133
  • 134
  • 135
  • 136
  • 137
  • 138
  • 139
  • 140
  • 141
  • 142
  • 143
  • 144
  • 145
  • 146
  • 147
  • 148
  • 149
  • 150
  • 151
  • 152
  • 153
  • 154
  • 155
  • 156
  • 157
  • 158
  • 159
  • 160
  • 161
  • 162
  • 163
  • 164
  • 165
  • 166
  • 167
  • 168
  • 169
  • 170
  • 171
  • 172
  • 173
  • 174
  • 175
  • 176
  • 177
  • 178
  • 179
  • 180
  • 181
  • 182
  • 183
  • 184
  • 185
  • 186
  • 187
  • 188
  • 189
  • 190
  • 191
  • 192
  • 193
  • 194
  • 195
  • 196
  • 197
  • 198
  • 199
  • 200
  • 201
  • 202
  • 203
  • 204
  • 205
  • 206
  • 207
  • 208
  • 209
  • 210
  • 211
  • 212
  • 213
  • 214
  • 215
  • 216
  • 217
  • 218
  • 219
  • 220
  • 221
  • 222
  • 223
  • 224
  • 225
  • 226
  • 227
  • 228
  • 229
  • 230
  • 231
  • 232
  • 233
  • 234
  • 235
  • 236
  • 237
  • 238
  • 239
  • 240
  • 241
  • 242
  • 243
  • 244
  • 245
  • 246
  • 247
  • 248
  • 249
  • 250
  • 251
  • 252
  • 253
  • 254
  • 255
  • 256
  • 257
  • 258
  • 259
  • 260
  • 261
  • 262
  • 263
  • 264
  • 265
  • 266
  • 267
  • 268
  • 269
  • 270
  • 271
  • 272
  • 273
  • 274
  • 275
  • 276
  • 277
  • 278
  • 279
  • 280
  • 281
  • 282
  • 283
  • 284
  • 285
  • 286
  • 287
  • 288
  • 289
  • 290
  • 291
  • 292
  • 293
  • 294
  • 295
  • 296
  • 297
  • 298
  • 299
  • 300
  • 301
  • 302
  • 303
  • 304
  • 305
  • 306
  • 307
  • 308
  • 309
  • 310
  • 311
  • 312
  • 313
  • 314
  • 315
  • 316
  • 317
  • 318
  • 319

  1. _a-zA-Z0-9 ↩︎

  2. 1-9 ↩︎

  3. 0-9 ↩︎

  4. a-z ↩︎

  5. A-Z ↩︎

  6. A-Za-z ↩︎

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是使用Vue3和Ant Design Vue进行表单验证的示例: ```vue <template> <a-form :form="form" @finish="handleSubmit"> <a-form-item label="名称" name="name" :rules="nameRules"> <a-input v-model="form.name" /> </a-form-item> <a-form-item label="对比项" name="compare" :rules="compareRules"> <a-input v-model="form.compare" /> </a-form-item> <a-form-item label="备注" name="remark" :rules="remarkRules"> <a-input v-model="form.remark" /> </a-form-item> <a-button type="primary" html-type="submit">提交</a-button> </a-form> </template> <script> import { defineComponent, ref } from 'vue'; import { Form, Input, Button } from 'ant-design-vue'; export default defineComponent({ components: { 'a-form': Form, 'a-form-item': Form.Item, 'a-input': Input, 'a-button': Button, }, setup() { const form = ref(null); const nameRules = [ { required: true, message: '名称不能为空' }, ]; const compareRules = [ { required: true, message: '对比项不能为空' }, ]; const remarkRules = [ { required: true, message: '备注不能为空' }, ]; const handleSubmit = () => { form.value.validate((valid) => { if (valid) { // 表单验证通过,执行提交操作 console.log('表单验证通过'); } else { console.log('表单验证失败'); } }); }; return { form, nameRules, compareRules, remarkRules, handleSubmit, }; }, }); </script> ``` 这个示例中,我们使用了Vue3的`defineComponent`和`ref`函数来定义组件和创建响应式数据。我们还引入了Ant Design Vue表单组件,包括`Form`、`FormItem`、`Input`和`Button`。 在模板中,我们使用`a-form`组件来创建表单,并将表单对象绑定到`form`变量上。每个表单项都使用`a-form-item`组件包裹,并设置相应的`name`和`rules`属性来进行验证。当点击提交按钮,我们调用`handleSubmit`方法来进行表单验证,如果验证通过,则执行提交操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值