vue實現(xiàn)登陸頁面開發(fā)實踐
組件使用的是vant ui,具體用法可去官網(wǎng)看。
分幾個部分考慮,
一、輸入框input的校驗:1、blur時沒有值和格式不符合的邏輯校驗
2、限制輸入長度邏輯,比如手機(jī)號只能11位,驗證碼只能6位。
二、驗證碼按鈕邏輯:
1、不同狀態(tài)下驗證碼顏色,文案,是否能點擊,是否顯示記數(shù)需要兼顧。
2、驗證碼能夠正常點擊是在手機(jī)號格式正確情況下,所以這里要有個監(jiān)聽手機(jī)號,一旦格式符合,驗證碼生效
3、關(guān)于計數(shù)器的邏輯。
以下會從上面的點開考慮:
一、input的校驗沒有可說的,記住倆點,一個控制輸入長度,一個控制格式。
1、格式校驗
handleblurtel(){ let phoneCodeVerification = /^[1][3,4,5,7,8][0-9]{9}$/; if(this.form.tel===''){ this.errorTxt="請輸入手機(jī)號碼" // 不同情況下錯誤提示 }else if(!phoneCodeVerification.test(this.form.tel)){ this.errorTxt="請輸入正確的手機(jī)號碼格式" }else{ this.errorTxt='' //有效情況記得清空錯誤提示 return true } }, // 驗證碼必填和格式驗證 handleblurcode(){ if(this.form.code===''){ this.errorTxtcode="請輸入驗證碼" }else if(this.form.code.length>0&&this.form.code.length<6){ this.errorTxtcode="請輸入正確的驗證碼格式" }else{ this.errorTxt='' return true } }
2、長度控制
// 限制輸入的字符串長度 hanldeInputTel(){//手機(jī)號長度保證11位 if(this.form.tel.length>11){ this.form.tel=this.form.tel.slice(0,11) } }, handleInputCode(){//驗證碼保證6位 if(this.form.code.length>6){ this.form.code=this.form.code.slice(0,6) } },
二、驗證碼邏輯:
貼下html代碼:
<van-field v-model="form.code" center clearable label="短信驗證碼" :error-message="errorTxtcode" placeholder="請輸入短信驗證碼" @input="handleInputCode" @blur="handleblurcode" > <template #button> <button size="small" :disabled="btnStatus" :class="btnStyle" type="primary" @click="clickCode"> <van-count-down :time="time" format="ss" v-if="countFlag===1" @finish="finishDown"></van-count-down> <span>{{countTxt}}</span> </button> </template> </van-field>
vant-count-down是vant組件自帶的計數(shù)器用法,直接引入,time是初始化時間數(shù),比如60s,1min,format是時間格式:時分秒,秒等。
@finish是自帶的方法,具體api可去官方網(wǎng)站看,這里不做介紹。
1、初始化按鈕狀態(tài):
data(){ return { form:{ tel:'', code:'' }, errorTxt:'',// 手機(jī)號錯誤提示 errorTxtcode:'',// 驗證碼錯誤提示 btnStatus:true,// 按鈕不可點擊 btnStyle: 'nomalStyle',// 促初始化按鈕樣式 time:60*1000,// 時間數(shù) countTxt:'發(fā)送驗證碼',// 初始化按鈕文案 countFlag:0//0:展示文案,1;展示計數(shù),開始計時 } },
1、開始計時:
按鈕狀態(tài)不可點擊狀態(tài)btnStatus,按鈕樣式:btnStyle,開始計數(shù):countFlag
// 點擊按鈕開始計時 clickCode(){ this.btnStatus=true this.btnStyle=`countdown` this.countFlag=1//開始計時 this.countTxt=''//文案為空 },
2、倒計時結(jié)束后:需要修改這些參數(shù)
按鈕可繼續(xù)點擊btnStatus,顯示文案countFlag,c文案內(nèi)容countTxt
// 倒計時結(jié)束 finishDown(){ this.btnStyle=`canClick` this.btnStatus=false this.countTxt='重新獲取' this.countFlag=0 },
3、按鈕狀態(tài)何時觸發(fā):
手機(jī)號符合格式情況下,watch里面監(jiān)聽手機(jī)號
watch:{ form: { handler() { if(/^[1][3,4,5,7,8][0-9]{9}$/.test(this.form.tel)){ this.btnStyle = 'canClick' this.btnStatus=false }else{ this.btnStatus=true } }, immediate: true, deep: true } },
4、最后點擊提交的簡單寫法:
// 提交用戶信息 sumbit(){ let telStatus=this.handleblurtel() let codeStatus=this.handleblurcode() if(telStatus&&codeStatus){ this.axios.get({}).then(res=>{ console.log('提交成功') // 把后端會的token存入前端緩存 localStorage.setItem('token',res.data.toekn) // 跳轉(zhuǎn)到首頁 this.$router.push({path:'/'}) }) } },
1,2,3步可以一步一步來,這樣思路就會清晰,不然會覺得驗證碼一會兒這樣顯示一會兒那樣顯示,就會很混亂,所以先把單個功能開發(fā)完,最后寫按鈕變化前提條件 這樣思路就很明確。
樣式放在文末:
.nomalStyle { background: #EAEEFD; color: #5E6679; } button { width: 161px; height: 61px; border-radius: 31px; line-height: 61px; font-size: 24px; text-align: center; } .canClick { background-color: #3E64D4; color: #FFFFFF; } .countdown { background: #EAEEFD; color: #3E64D4 }
到此這篇關(guān)于vue實現(xiàn)登陸頁面開發(fā)實踐的文章就介紹到這了,更多相關(guān)vue 登陸頁面內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue 動態(tài)樣式綁定 class/style的寫法小結(jié)
這篇文章主要介紹了vue 動態(tài)樣式綁定 class/style的寫法小結(jié),本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03vue-element-admin登錄攔截設(shè)置白名單方式
這篇文章主要介紹了vue-element-admin登錄攔截設(shè)置白名單方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03vue+echarts實現(xiàn)動態(tài)繪制圖表及異步加載數(shù)據(jù)的方法
vue寫的后臺管理,需要將表格數(shù)據(jù)繪制成圖表(折線圖,柱狀圖),圖表數(shù)據(jù)都是通過接口請求回來的。這篇文章主要介紹了vue+echarts 動態(tài)繪制圖表及異步加載數(shù)據(jù)的相關(guān)知識,需要的朋友可以參考下2018-10-10Vue 集成 PDF.js 實現(xiàn) PDF 預(yù)覽和添加水印的步驟
這篇文章主要介紹了如何在 Vue 中集成 Mozilla/PDF.js ,實現(xiàn)自定義的 PDF 預(yù)覽器,以及給被預(yù)覽的 PDF 添加水印2021-01-01