欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue實(shí)現(xiàn)短信驗(yàn)證碼登錄功能(流程詳解)

 更新時(shí)間:2019年12月10日 09:38:54   作者:Haisen''''Blogs  
無論是移動端還是pc端登錄或者注冊界面都會見到手機(jī)驗(yàn)證碼登錄這個(gè)功能,輸入手機(jī)號,得到驗(yàn)證碼,這篇文章主要介紹了基于vue實(shí)現(xiàn)短信驗(yàn)證碼登錄功能,需要的朋友可以參考下

無論是移動端還是pc端登錄或者注冊界面都會見到手機(jī)驗(yàn)證碼登錄這個(gè)功能,輸入手機(jī)號,得到驗(yàn)證碼,最后先服務(wù)器發(fā)送請求,保存登錄的信息,一個(gè)必不可少的功能

思路

1,先判斷手機(jī)號和驗(yàn)證是否為空,

2,點(diǎn)擊發(fā)送驗(yàn)證碼,得到驗(yàn)證碼

3,輸入的驗(yàn)證碼是否為空和是否正確,

4,最后向服務(wù)發(fā)送請求

界面展示

1.準(zhǔn)備工作

這個(gè)會對input進(jìn)行封裝處理

<template>
 <div class="text_group">
  <div class="input_group" :class="{'is-invalid': error}">
   <!-- 輸入框 -->
   <input 
    :type="type"
    :placeholder="placeholder"
    :value="value"
    :name="name"
    @input="$emit('input',$event.target.value)"
   >
   <!-- 輸入框后面的內(nèi)容 -->
   <button v-if="btnTitle" @click="$emit('btnClick')" :disabled="disabled">{{btnTitle}}</button>
  </div>
  <!-- 驗(yàn)證提示 -->
  <div v-if="error" class="invalid-feedback">{{error}}</div>
 </div>
</template>
<script>
 export default {
  name:"inputGroup",
  props:{
   type: {
    type: String,
    default: "text"
   },
   placeholder:String,
   value:String,
   name:String,
   disabled:Boolean,
   btnTitle:String, //input框中的文字
   error:String //驗(yàn)證不正確提示
  }
 }
</script>

input組件封裝完之后在我們這個(gè)login組件中引入并注冊

import InputGroup from '../components/InputGroup'引入封裝的組件

最后在components注冊

data() {
 return {
  phone:"", //手機(jī)號
  verifyCode:"", //驗(yàn)證碼
  btnTitle:"獲取驗(yàn)證碼",
  disabled:false, //是否可點(diǎn)擊
  errors:{}, //驗(yàn)證提示信息
 }
 }

<template>
 <div class="login">
  <!-- 手機(jī)號 -->
  <InputGroup
   type="number"
   placeholder="手機(jī)號"
   v-model="phone" 
   :btnTitle="btnTitle"
   :disabled="disabled"
   :error="errors.phone"
   @btnClick="getVerifyCode"
  />
  <!-- 輸入驗(yàn)證碼 -->
  <InputGroup
   type="number"
   v-model="verifyCode"
   placeholder="驗(yàn)證碼"
   :error="errors.code"
  />
  <!-- 登錄按鈕 -->
         
 <div class="login_btn">
   <button @click="handleLogin" :disabled="isClick">登錄</button>
  </div>
 </div>
 </template> 

2.判斷手機(jī)號是否正確和合法

(1)點(diǎn)擊驗(yàn)證碼發(fā)送驗(yàn)證的時(shí)候,必須符合手機(jī)號正確和手機(jī)號碼不能為空,短信發(fā)送服務(wù)用的是《聚合數(shù)據(jù)》,申請可以免費(fèi)調(diào)用10次

getVerifyCode(){

//獲取驗(yàn)證碼
if(this.validatePhone()) {
 this.validateBtn()
 //發(fā)送網(wǎng)絡(luò)請求
 this.$axios.post('/api/posts/sms_send',{<br>        //注冊聚合數(shù)據(jù)找到短信api服務(wù),申請會得到兩個(gè)tpl_id和key值,然后填入相對應(yīng)的就行,具體還是和你門后端進(jìn)行溝通
  tpl_id: "",
    key: "",
  phone:this.phone
 }).then(res => {
  console.log(res)
 })
 }<br>},

2.1點(diǎn)擊發(fā)送驗(yàn)證碼的時(shí)候判斷是否合法

validatePhone(){
 //判斷輸入的手機(jī)號是否合法
 if(!this.phone) {
 this.errors = {
 phone:"手機(jī)號碼不能為空"
 }
 // return false
 } else if(!/^1[345678]\d{9}$/.test(this.phone)) {
 this.errors = {
 phone:"請輸入正確是手機(jī)號"
 }
 // return false
 } else {
 this.errors ={}
 return true
 }
}, 

2.2點(diǎn)擊驗(yàn)證碼發(fā)送倒計(jì)時(shí)

validateBtn(){
 //倒計(jì)時(shí)
 let time = 60;
 let timer = setInterval(() => {
 if(time == 0) {
 clearInterval(timer);
 this.disabled = false;
 this.btnTitle = "獲取驗(yàn)證碼";
 } else {
 this.btnTitle =time + '秒后重試';
 this.disabled = true;
 time--
 }
 },1000)
},

3.點(diǎn)擊登錄實(shí)現(xiàn)

  3.1點(diǎn)擊登錄之前手機(jī)已經(jīng)發(fā)送驗(yàn)證密,并且手機(jī)上以及獲取到正確的驗(yàn)證碼,登錄之前需要判斷,手機(jī)號和驗(yàn)證碼都不能為空,所以在計(jì)算屬性判斷是否兩個(gè)都為空,如果都不為空的話,可以點(diǎn)擊按鈕,否則不能點(diǎn)擊按鈕

computed: {
 //手機(jī)號和驗(yàn)證碼都不能為空
 isClick(){
  if(!this.phone || !this.verifyCode) {
  return true
  } else {
  return false
  }
     
 }
},

  3.2點(diǎn)擊登錄發(fā)送請求,得到的并存儲到localStorage里面,最后跳轉(zhuǎn)到登錄頁面

handleLogin() {
 //點(diǎn)擊發(fā)送
 this.errors = {};
 this.$axios.post('/api/posts/sms_back',{
  phone:this.phone,
  code:this.verifyCode
 }).then(res => {
  console.log(res);
  localStorage.setItem('ele_login',true)
  this.$router.push('/')
 }).catch(error =>{
  //返回錯(cuò)誤信息
  this.errors ={
  code:error.response.data.msg
 }
 })
}

總結(jié)

以上所述是小編給大家介紹的vue實(shí)現(xiàn)短信驗(yàn)證碼登錄功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • vue實(shí)現(xiàn)拖動左側(cè)導(dǎo)航欄變大變小

    vue實(shí)現(xiàn)拖動左側(cè)導(dǎo)航欄變大變小

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)拖動左側(cè)導(dǎo)航欄變大變小,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue-cli2.9.3 詳細(xì)教程

    vue-cli2.9.3 詳細(xì)教程

    這篇文章主要介紹了vue-cli2.9.3 詳細(xì)教程,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-04-04
  • 如何修改vue-treeSelect的高度

    如何修改vue-treeSelect的高度

    這篇文章主要介紹了如何修改vue-treeSelect的高度,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • 詳解使用webpack打包編寫一個(gè)vue-toast插件

    詳解使用webpack打包編寫一個(gè)vue-toast插件

    本篇文章主要介紹了詳解使用webpack打包編寫一個(gè)vue插件,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11
  • 使用Vue.js和Element-UI做一個(gè)簡單登錄頁面的實(shí)例

    使用Vue.js和Element-UI做一個(gè)簡單登錄頁面的實(shí)例

    下面小編就為大家分享一篇使用Vue.js和Element-UI做一個(gè)簡單登錄頁面的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Vue使用vue-draggable 插件在不同列表之間拖拽功能

    Vue使用vue-draggable 插件在不同列表之間拖拽功能

    這篇文章主要介紹了使用vue-draggable 插件在不同列表之間拖拽,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-03-03
  • vue下載二進(jìn)制流圖片操作

    vue下載二進(jìn)制流圖片操作

    這篇文章主要介紹了vue下載二進(jìn)制流圖片操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • element-ui 表格sortable排序手動js清除方式

    element-ui 表格sortable排序手動js清除方式

    這篇文章主要介紹了element-ui 表格sortable排序手動js清除方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-07-07
  • elementUI?el-table二次封裝的詳細(xì)實(shí)例

    elementUI?el-table二次封裝的詳細(xì)實(shí)例

    在項(xiàng)目中會多次使用表格展示數(shù)據(jù),不對這個(gè)table進(jìn)行二次封裝成我們自己想要的,重復(fù)的代碼量的工作會比較大,下面這篇文章主要給大家介紹了關(guān)于elementUI?el-table二次封裝的相關(guān)資料,需要的朋友可以參考下
    2023-03-03
  • VUE實(shí)現(xiàn)注冊與登錄效果

    VUE實(shí)現(xiàn)注冊與登錄效果

    這篇文章主要為大家詳細(xì)介紹了VUE實(shí)現(xiàn)注冊與登錄效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09

最新評論