Flutter之Timer實現(xiàn)短信驗證碼獲取60s倒計時功能的代碼
先看下效果:

兩種需求場景:
1.廣告頁3s后跳轉(zhuǎn)到首頁
2.短信驗證碼60s倒計時
第一種的話,根據(jù)需求我們可以知道,我們想要的效果就是3s結(jié)束做出一個動作。
factory Timer(Duration duration, void callback()) {
if (Zone.current == Zone.root) {
// No need to bind the callback. We know that the root's timer will
// be invoked in the root zone.
return Zone.current.createTimer(duration, callback);
}
return Zone.current
.createTimer(duration, Zone.current.bindCallbackGuarded(callback));
}
兩個參數(shù),第一個參數(shù)超時時間,即多久后執(zhí)行你想要的動作,第二個參數(shù)callback回調(diào)方法,即超時后你想要執(zhí)行的動作是什么,比如跳轉(zhuǎn)到首頁。
第二種的話就是需要不斷的做出倒計時的動作。
factory Timer.periodic(Duration duration, void callback(Timer timer)) {
if (Zone.current == Zone.root) {
// No need to bind the callback. We know that the root's timer will
// be invoked in the root zone.
return Zone.current.createPeriodicTimer(duration, callback);
}
var boundCallback = Zone.current.bindUnaryCallbackGuarded<Timer>(callback);
return Zone.current.createPeriodicTimer(duration, boundCallback);
}
這種調(diào)用方式和上面的方式的區(qū)別是:第一種只會回調(diào)一次,就是超時時間到了之后執(zhí)行callback回調(diào)方法,而Timer.periodic調(diào)用方式是循環(huán)不斷的調(diào)用,比如說通過這種方式,你設(shè)置的超時時間是1s的話,那就會每隔1s調(diào)用一次callback的回調(diào)方法,也就是通過這種方式來實現(xiàn)我們的短信驗證碼60s倒計時獲取。
看下具體用法吧:
Timer _timer; int _timeCount = 60;
觸發(fā)事件:
onTap: () {
_startTimer();
},
處理方法:
void _startTimer() {
ToastUtil.showTips('短信驗證碼已發(fā)送,請注意查收');
_timer = Timer.periodic(Duration(seconds: 1), (Timer timer) => {
setState(() {
if(_timeCount <= 0){
_autoCodeText = '重新獲取';
_timer.cancel();
_timeCount = 60;
}else {
_timeCount -= 1;
_autoCodeText = "$_timeCount" + 's';
}
})
});
}
到此這篇關(guān)于Flutter之Timer實現(xiàn)短信驗證碼獲取60s倒計時功能的代碼的文章就介紹到這了,更多相關(guān)Flutter短信驗證碼倒計時內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Android Studio綁定下拉框數(shù)據(jù)詳解
這篇文章主要為大家詳細(xì)介紹了Android Studio綁定下拉框數(shù)據(jù),Android Studio綁定網(wǎng)絡(luò)JSON數(shù)據(jù),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-10-10
Android 實現(xiàn)抖音小游戲潛艇大挑戰(zhàn)的思路詳解
《潛水艇大挑戰(zhàn)》是抖音上的一款小游戲,最近特別火爆,很多小伙伴都玩過。接下來通過本文給大家分享Android 手?jǐn)]抖音小游戲潛艇大挑戰(zhàn)的思路,需要的朋友可以參考下2020-04-04
簡介Android應(yīng)用中sharedPreferences類存儲數(shù)據(jù)的用法
這篇文章主要介紹了Android應(yīng)用中使用sharedPreferences類存儲數(shù)據(jù)的方法,文中舉了用SharedPreferences保存數(shù)據(jù)和讀取數(shù)據(jù)的例子,需要的朋友可以參考下2016-02-02
淺析Android手機(jī)衛(wèi)士之手機(jī)實現(xiàn)短信指令獲取位置
這篇文章主要介紹了淺析Android手機(jī)衛(wèi)士之手機(jī)實現(xiàn)短信指令獲取位置的相關(guān)資料,需要的朋友可以參考下2016-04-04
Android Studio3.2中導(dǎo)出jar包的過程詳解
這篇文章主要介紹了Android Studio3.2中導(dǎo)出jar包的過程,本文分步驟給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06
android 6.0 權(quán)限授權(quán)方法
今天小編就為大家分享一篇android 6.0 權(quán)限授權(quán)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-07-07

