亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

Swift實現iOS應用中短信驗證碼倒計時功能的實例分享

2020-07-26 03:22:14
字體:
來源:轉載
供稿:網友

在開始之前,我們先來了解一個概念 屬性觀測器(Property Observers):

屬性觀察器監控和響應屬性值的變化,每次屬性被設置值的時候都會調用屬性觀察器,甚至新的值和現在的值相同的時候也不例外。

可以為屬性添加如下的一個或全部觀察器:

  • willSet在新的值被設置之前調用
  • didSet在新的值被設置之后立即調用

接下來開始我們的教程,先展示一下最終效果:

2016418144945893.gif (372×180)

首先聲明一個發送按鈕:

復制代碼 代碼如下:

var sendButton: UIButton!

在viewDidLoad方法中給發送按鈕添加屬性:
復制代碼 代碼如下:

override func viewDidLoad() {
    super.viewDidLoad()

    sendButton = UIButton()
    sendButton.frame = CGRect(x: 40, y: 100, width: view.bounds.width - 80, height: 40)
    sendButton.backgroundColor = UIColor.redColor()
    sendButton.setTitleColor(UIColor.whiteColor(), forState: .Normal)
    sendButton.setTitle("獲取驗證碼", forState: .Normal)
    sendButton.addTarget(self, action: "sendButtonClick:", forControlEvents: .TouchUpInside)

    self.view.addSubview(sendButton)
}


接下來聲明一個變量remainingSeconds代表當前倒計時剩余的秒數:
復制代碼 代碼如下:

var remainingSeconds = 0

我們給remainingSeconds添加一個willSet方法,這個方法會在remainingSeconds的值將要變化的時候調用,并把值傳遞給參數newValue:
復制代碼 代碼如下:

var remainingSeconds: Int = 0 {
    willSet {
        sendButton.setTitle("驗證碼已發送(/(newValue)秒后重新獲取)", forState: .Normal)

        if newValue <= 0 {
            sendButton.setTitle("重新獲取驗證碼", forState: .Normal)
            isCounting = false
        }
    }
}


當remainingSeconds變化時更新sendButton的顯示文本。

倒計時的功能我們用NSTimer實現,先聲明一個NSTimer實例:

復制代碼 代碼如下:

var countdownTimer: NSTimer?

然后我們聲明一個變量來開啟和關閉倒計時:
復制代碼 代碼如下:

var isCounting = false {
    willSet {
        if newValue {
            countdownTimer = NSTimer.scheduledTimerWithTimeInterval(1, target: self, selector: "updateTime", userInfo: nil, repeats: true)

            remainingSeconds = 10
            sendButton.backgroundColor = UIColor.grayColor()
        } else {
            countdownTimer?.invalidate()
            countdownTimer = nil

            sendButton.backgroundColor = UIColor.redColor()
        }

        sendButton.enabled = !newValue
    }
}


同樣,我們給isCounting添加一個willSet方法,當isCounting的newValue為true時,我們通過調用NSTimer的類方法
scheduledTimerWithTimeInterval:target:selector:userInfo:repeats:創建并啟動剛才聲明的countdownTimer實例,這個實例每一秒鐘調用一次updateTime:方法:
復制代碼 代碼如下:

func updateTime(timer: NSTimer) {
     // 計時開始時,逐秒減少remainingSeconds的值
    remainingSeconds -= 1
}

當isCounting的newValue為false時,我們停止countdownTimer并將countdownTimer設置為nil。

此外我們還設置了倒計時的時間(這里為了演示時間設置為5秒)和發送按鈕在不同isCounting狀態下的樣式(這里調整了背景色)和是否可點擊。

最后實現sendButtonClick:方法,這個方法在點擊sendButton時調用:

復制代碼 代碼如下:

 func sendButtonClick(sender: UIButton) {
    // 啟動倒計時
    isCounting = true
}

完成!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品情侣自拍| 色偷偷888欧美精品久久久| 久久精品99久久久香蕉| 亚洲一区亚洲二区| 97久久久久久| 亚洲视频在线观看网站| 国产不卡视频在线| 成人在线免费观看视视频| 国产亚洲xxx| 午夜精品久久久久久久久久久久| 欧美性猛交xxxx富婆| 亚洲精品成人久久电影| 久久久久久亚洲精品中文字幕| 久久97久久97精品免视看| 国产精品7m视频| 高清日韩电视剧大全免费播放在线观看| 欧美精品18videos性欧| 欧美另类精品xxxx孕妇| 久久青草精品视频免费观看| 欧美午夜久久久| 亚洲第一区在线观看| 国产精品尤物福利片在线观看| 久久综合五月天| 国产在线观看91精品一区| 国产精品视频公开费视频| 欧美激情在线观看视频| 欧美电影在线观看网站| 国产精品久久精品| 自拍视频国产精品| 国产精品一区二区三区毛片淫片| 96sao精品视频在线观看| 日本精品免费一区二区三区| 国产精品三级在线| 欧美日韩国产中字| 伊人久久男人天堂| 日韩精品中文字幕久久臀| 欧美一级成年大片在线观看| 国产精品xxxxx| 欧美大片在线看免费观看| 国产精品99免视看9| 成人自拍性视频| 国产欧美精品日韩精品| 国产精品高清在线| 综合欧美国产视频二区| 最新日韩中文字幕| 精品久久久久久| 97视频在线播放| 欧美日韩在线视频首页| 中文字幕欧美精品日韩中文字幕| 欧美午夜精品久久久久久久| 国产69精品久久久久99| 精品国产区一区二区三区在线观看| 国产美女精品免费电影| 欧美成人性色生活仑片| 久久久久久久久久av| 在线电影av不卡网址| 亚洲第一网站免费视频| 欧美激情精品久久久久久大尺度| 亚洲最新在线视频| 一区二区三区日韩在线| 国产午夜一区二区| 亚洲欧洲国产一区| 亚洲综合在线中文字幕| 高跟丝袜欧美一区| 欧美电影免费观看高清| 5566成人精品视频免费| 国产精品福利在线观看网址| 亚洲国产精久久久久久久| 国模叶桐国产精品一区| 91亚洲精品视频| 精品亚洲一区二区三区四区五区| 一个人看的www久久| 欧美激情视频在线观看| 九九热精品视频| 日本久久精品视频| 91性高湖久久久久久久久_久久99| 久久福利网址导航| 日韩精品视频免费专区在线播放| 亚洲精品乱码久久久久久金桔影视| 亚洲欧美另类自拍| 亚洲国产精品嫩草影院久久| 18一19gay欧美视频网站| 国产精品第一页在线| 国产欧美日韩丝袜精品一区| 97精品国产91久久久久久| 中文字幕亚洲无线码a| 成人久久精品视频| 欧美日韩人人澡狠狠躁视频| 97在线日本国产| 国产成人激情小视频| 国产69精品久久久久9| 欧美高清videos高潮hd| 久久这里有精品视频| 亚洲福利视频免费观看| 在线日韩中文字幕| 国产97在线|亚洲| 国产精品夜间视频香蕉| 中文字幕欧美日韩精品| 91精品久久久久久久久久入口| 日韩精品亚洲精品| 国产精品网站入口| 粉嫩老牛aⅴ一区二区三区| 久久精品免费电影| 91精品免费视频| 亚洲香蕉伊综合在人在线视看| 亚洲欧美中文日韩v在线观看| 国产精品电影网站| 亚洲欧美制服中文字幕| 亚洲黄色免费三级| 国产亚洲精品久久久| 亚洲男人av在线| 久久激情五月丁香伊人| 91精品国产自产在线| 韩国日本不卡在线| 亚洲欧美综合另类中字| 色偷偷偷亚洲综合网另类| 一本色道久久88亚洲综合88| 久久高清视频免费| 精品福利视频导航| 亚洲品质视频自拍网| 中文字幕亚洲激情| 一区二区国产精品视频| 欧美日韩在线另类| 91tv亚洲精品香蕉国产一区7ujn| 91亚洲一区精品| 国产三级精品网站| 免费成人高清视频| 美女久久久久久久久久久| 国产精品91久久久| 欧美精品情趣视频| 欧美综合一区第一页| 日韩成人高清在线| 亚洲天堂久久av| 日本一本a高清免费不卡| 亚洲欧美在线免费| 欧美在线免费观看| 亚洲欧美日本伦理| 久久久av网站| 精品中文字幕在线观看| 97**国产露脸精品国产| 日韩精品视频在线播放| 亚洲乱码一区av黑人高潮| 91美女高潮出水| 亚洲国产91精品在线观看| 国产成人福利夜色影视| 97久久久免费福利网址| 国产97在线亚洲| 亚洲精品免费一区二区三区| 91精品综合久久久久久五月天| 成人观看高清在线观看免费| 色av吧综合网| 国产999精品| 91热精品视频| 欧美黑人性猛交| 91亚洲精品久久久| 国产欧美中文字幕| 亚洲欧洲国产伦综合| 亚洲午夜女主播在线直播| 国内外成人免费激情在线视频| 欧美性xxxx在线播放| 一区二区国产精品视频| 国产精品自拍视频| 欧美一级淫片播放口| 亚洲精品短视频|