網(wǎng)站首頁 編程語言 正文
解決 el-form 異步校驗導致重復校驗的問題
業(yè)務邏輯
最近項目上有個業(yè)務,確認表單,需要用到手機驗證碼,驗證是否為本人操作。這挺常見的,但是需要用戶填寫完,輸入框失去焦點時就將驗證碼發(fā)送后臺進行驗證,而且驗證碼只能輸一次。
觸發(fā)場景
若用戶輸入完驗證碼后,鼠標焦點并未離開,直接點擊確認的話,因為 validator 異步的關系,鼠標離開焦點觸發(fā)一次校驗,確認也觸發(fā)一次校驗,導致 重復校驗,用戶體驗極差
解決辦法
用watch 動態(tài)監(jiān)聽 form 表單里驗證碼輸入框的值,并進行相應判斷,輸入長度為6時自動觸發(fā)驗證
<template>
<el-form ref="form" :model="form" :rules="rules" label-width="160px" label-suffix=" :">
<el-form-item label="手機驗證碼" prop="sms" :rules="{ validator : sms , required : true , trigger : 'blur'}" key="sms">
<!-- 驗證碼輸入框 -->
<el-input v-model="form.sms" maxlength="6" show-word-limit/>
<!-- 發(fā)送驗證碼組件 -->
<simple-sms :api="POST_DSP_SEND" />
</el-form-item>
</el-form>
</template>
<script>
watch : {
'form.sms': function (val) { //單個數(shù)據(jù)驗證
if(val!= undefined && val.length == 6){
this.validateField('sms')
}
}
} ,
methods : {
//表單單項驗證
validateField(fieldName) {
this.$refs.form.validateField(fieldName)
} ,
// 驗證碼驗證
sms(r , v , c) {
if (!v) {
return c(new Error('請輸入驗證碼'))
} else if (this.validPass){ // validPass 字段代表驗證成功
c()
}
if(!this.loading){
this.loading = true
http.post(this.POST_DSP_VERIFY, {code: v}).then(() => {
// 驗證成功
this.validPass = true
return c()
}).catch(() => {
return c(new Error('請輸入正確驗證碼'))
}).finally(()=>{
// 按鈕啟用
this.loading = false
})
}
},
}
</script>
這里主要是提供一個思路,利用watch去監(jiān)聽form的數(shù)據(jù)來觸發(fā)驗證;也能通過禁用確認按鈕先進行驗證來完成,如果你有更好的辦法,非常歡迎你在評論教教我
原文鏈接:https://blog.csdn.net/qq_43850819/article/details/108004012
相關推薦
- 2022-04-08 Python?如何實現(xiàn)變量交換_python
- 2022-11-18 Flutter使用push?pop方法及路由進行導航詳解_IOS
- 2022-11-20 python合并多個excel的詳細過程_python
- 2022-11-16 Kotlin條件控制語句匯總講解_Android
- 2022-05-19 redis擊穿?雪崩?穿透超詳細解決方案梳理_Redis
- 2022-06-26 React?Native?加載H5頁面的實現(xiàn)方法_React
- 2022-05-09 python?itertools包內置無限迭代器_python
- 2023-02-18 go?micro微服務框架項目搭建方法_Golang
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支