Ionic學(xué)習(xí)日記實(shí)現(xiàn)驗(yàn)證碼倒計(jì)時(shí)
前言
要做一個(gè)app的話,肯定會(huì)涉及到這個(gè)功能,所以就從網(wǎng)上找了許多前輩的資料,找到了一個(gè)最適合自己并且方便理解的實(shí)現(xiàn)此功能,寫(xiě)此日記方便未來(lái)自己復(fù)習(xí)和其他人學(xué)習(xí)
思路
在用戶(hù)注冊(cè)的時(shí)候,時(shí)下不少app都選擇了綁定手機(jī)號(hào)注冊(cè),這是一個(gè)非常好的想法,便捷用戶(hù)操作,也很方便遵循實(shí)名制的問(wèn)題,在設(shè)計(jì)按鈕的時(shí)候,需要讓他顯示在輸入驗(yàn)證碼的旁邊,并在用戶(hù)點(diǎn)擊后,開(kāi)始倒計(jì)時(shí),并將按鈕變成無(wú)法點(diǎn)擊效果
點(diǎn)擊前
點(diǎn)擊后
在本篇日記中只涉及到1個(gè)page下的文件,包括html、ts和scss(我的頁(yè)面名為reg,可根據(jù)自己的具體情況進(jìn)行調(diào)整)
在reg.ts定義在html中可以獲取到的信息
//驗(yàn)證碼倒計(jì)時(shí) verifyCode: any = { verifyCodeTips: "獲取驗(yàn)證碼", countdown: 60, disable: true }
reg.html設(shè)計(jì)布局
上面的圖片是我自己設(shè)計(jì)的,這里只取關(guān)鍵代碼
<button item-right ion-button clear (click)="getCode()" [disabled]="!verifyCode.disable">{{verifyCode.verifyCodeTips}}</button>
點(diǎn)擊事件getCode(),設(shè)置[disabled]是否可以點(diǎn)擊按鈕,用boolean值判斷,主要顯示的內(nèi)容是verifyCode.verifyCodeTips,即文本信息和之后需要實(shí)現(xiàn)的倒計(jì)時(shí)
reg.ts添加方法和倒計(jì)時(shí)處理
當(dāng)點(diǎn)擊button后將觸發(fā)getCode()方法,觸發(fā)該方法后首先將disable的值改變?yōu)閒alse,將按鈕設(shè)為不可點(diǎn)擊,然后觸發(fā)settime方法
getCode() { //點(diǎn)擊按鈕后開(kāi)始倒計(jì)時(shí) this.verifyCode.disable = false; this.settime(); }
settime()具體實(shí)現(xiàn)倒計(jì)時(shí)功能
//倒計(jì)時(shí) settime() { if (this.verifyCode.countdown == 1) { this.verifyCode.countdown = 60; this.verifyCode.verifyCodeTips = "獲取驗(yàn)證碼"; this.verifyCode.disable = true; return; } else { this.verifyCode.countdown--; } this.verifyCode.verifyCodeTips = "重新獲取"+this.verifyCode.countdown+"秒"; setTimeout(() => { this.verifyCode.verifyCodeTips = "重新獲取"+this.verifyCode.countdown+"秒"; this.settime(); }, 1000); }
用每過(guò)1秒計(jì)數(shù)器減1,簡(jiǎn)單的倒計(jì)時(shí)功能,重要的是判斷計(jì)數(shù)器是否為1,當(dāng)為1后就將verifyCode的3個(gè)信息重新初始化
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
一個(gè)友好的.改善的 Object.prototype.toString的實(shí)現(xiàn)
一個(gè)友好的.改善的 Object.prototype.toString的實(shí)現(xiàn)...2007-04-04XMLHTTP 亂碼的解決方法(UTF8,GB2312 編碼 解碼)
XMLHTTP 亂碼的解決方法(UTF8,GB2312 編碼 解碼)(附帶解決DHTMLX不能用中文的問(wèn)題)2011-01-01解決Layui數(shù)據(jù)表格顯示無(wú)數(shù)據(jù)提示的問(wèn)題
今天小編就為大家分享一篇解決Layui數(shù)據(jù)表格顯示無(wú)數(shù)據(jù)提示的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11JavaScript中的一些隱式轉(zhuǎn)換和總結(jié)(推薦)
這篇文章主要介紹了JavaScript中的一些隱式轉(zhuǎn)換和總結(jié),非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-12-12JS/HTML5游戲常用算法之碰撞檢測(cè) 像素檢測(cè)算法實(shí)例詳解
這篇文章主要介紹了JS/HTML5游戲常用算法之碰撞檢測(cè) 像素檢測(cè)算法,結(jié)合實(shí)例形式詳細(xì)分析了javascript像素檢測(cè)碰撞算法的原理、實(shí)現(xiàn)步驟及相關(guān)操作技巧,需要的朋友可以參考下2018-12-12js中AppendChild與insertBefore的用法詳細(xì)解析
這篇文章主要是對(duì)js中AppendChild與insertBefore的用法進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-12-12