一. 要求

1.点击获取验证码按钮,60秒倒计时,按钮变成不可点击状态,按钮文字变成倒计时的秒数.

2.当倒计时为0的时候,释放掉定时器NSTimer,按钮变成可以点击状态,按钮文字变成"获取验证码".

二.

//  ViewController.m

//  Demo-验证码

//

//  Created by quhaola on 16/4/11.

//  Copyright © 2016年 MC. All rights reserved.

//

#import "ViewController.h"

#import "Masonry.h"

@interface ViewController ()

{

NSTimer       *_timer;     //定时器

NSInteger      _second;    //倒计时的时间

}

@property (nonatomic, strong) UITextField    * textField;

@property (nonatomic, strong) UIButton       * authCodeButton;

@end

@implementation ViewController

#pragma mark - 生命周期

- (void)viewDidLoad

{

[super viewDidLoad];

//创建验证码按钮

[self addAuthCodeButton];

}

#pragma mark - 实现方法

- (void)addAuthCodeButton

{

//输入框

[self.view addSubview:self.textField];

[self.textField mas_makeConstraints:^(MASConstraintMaker *make) {

make.left.equalTo(self.view.mas_left).with.offset(10);

make.top.equalTo(self.view.mas_top).with.offset(100);

make.height.mas_equalTo(40);

make.width.mas_equalTo(200);

}];

//获取验证码按钮

[self.view addSubview:self.authCodeButton];

[self.authCodeButton mas_makeConstraints:^(MASConstraintMaker *make) {

make.left.equalTo(self.textField.mas_right).with.offset(20);

make.right.equalTo(self.view.mas_right).with.offset(-20);

make.top.equalTo(self.view.mas_top).with.offset(100);

make.height.mas_equalTo(40);

}];

}

#pragma mark - 点击事件

//获取验证码按钮的点击事件

- (void)authCodeButtonClicked

{

// 按钮点击之后的操作   --->  按钮不可点击,按钮背景颜色改变

self.authCodeButton.enabled = NO;

self.authCodeButton.backgroundColor = [UIColor grayColor];

// 设置倒计时的总时间

_second = 10;

// 创建计时器

_timer = [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(changeTime) userInfo:nil repeats:YES];

// (可以不考虑) 把清空textField数据

self.textField.text = nil;

}

#pragma mark 定时器调用的方法

- (void)changeTime

{

//每一秒调用一次改方法, 每次调用,_second 减一.

_second --;

//修改倒计时标签文字   ->   把按钮文字改成倒计时的时间

[self.authCodeButton setTitle:[NSString stringWithFormat:@"%@ s",@(_second)] forState:UIControlStateNormal];

//如果时间到了 0 秒, 把定时器取消掉

if (_second == -1)

{

//释放定时器

[_timer invalidate];

//把定时器设置成空.不然不起作用.

_timer = nil;

//把修改的验证码按钮调整为初始状态

self.authCodeButton.enabled = YES;

[self.authCodeButton setTitle:@"获取验证码" forState:UIControlStateNormal];

self.authCodeButton.backgroundColor = [UIColor orangeColor];

self.textField.text = @"这里是你请求的验证码";

}

}

#pragma mark - 验证码按钮

- (UITextField *)textField

{

if (!_textField)

{

self.textField = [[UITextField alloc] init];

self.textField.backgroundColor = [UIColor colorWithWhite:0.9 alpha:1];

}

return _textField;

}

- (UIButton *)authCodeButton

{

if (!_authCodeButton)

{

self.authCodeButton = [UIButton buttonWithType:UIButtonTypeCustom];

self.authCodeButton.backgroundColor = [UIColor orangeColor];

[self.authCodeButton setTitle:@"获取验证码" forState:UIControlStateNormal];

[self.authCodeButton addTarget:self action:@selector(authCodeButtonClicked) forControlEvents:UIControlEventTouchUpInside];

}

return _authCodeButton;

}

@end

iOS-验证码倒计时60秒的更多相关文章

  1. js 验证码 倒计时60秒

    js 验证码 倒计时60秒 <input type="button" id="btn" value="免费获取验证码" /> & ...

  2. vue实现验证码倒计时60秒的具体代码

    vue实现验证码倒计时60秒的具体代码 <span v-show="show" @click="getCode">获取验证码</span> ...

  3. jQuery实现发送验证码倒计时60秒

    前端HMTL: <div class="form_box"> <div class="line mb40"> <div class ...

  4. javaScript 验证码 倒计时60秒

    <input type="button" id="btn" value="免费获取验证码" /> <script type ...

  5. Android 实现简单 倒计时60秒,一次1秒

    倒计时功能如上图所示,其实就几行代码即可实现效果啦!!! /** 倒计时60秒,一次1秒 */ CountDownTimer timer = new CountDownTimer(60*1000, 1 ...

  6. js实现倒计时60秒的简单代码

    <!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Conten ...

  7. js 简单实现获取短信按钮倒计时60秒

    <!DOCTYPE html><html lang="en"><head> <meta http-equiv="Content- ...

  8. Jquery插件实现点击获取验证码后60秒内禁止重新获取

    通过jquery.cookie.js插件可以快速实现“点击获取验证码后60秒内禁止重新获取(防刷新)”的功能 先到官网(http://plugins.jquery.com/cookie/ )下载coo ...

  9. jQuery实现发送短信验证码后60秒倒计时

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script sr ...

随机推荐

  1. 新版PHP 7效能實測:Drupal 7能快70%,碎形計算大勝Ruby和Python

    PHP 7才剛在12月3日正式釋出,網頁開發框架Zend公司立刻發表了一份PHP新舊版效能大車拼報告,除了PHP 7和PHP 5.6之外,也把HHVM 3.7版納入一起比較. Zend公司選擇了幾套知 ...

  2. gson 自定义对象转换格式

    有时候我们希望gson按照我们想要的方式转换,比如将日期转换为时间戳 class GsonBuilderUtil { public static Gson create() { GsonBuilder ...

  3. zz 圣诞丨太阁所有的免费算法视频资料整理

    首发于 太阁实验室 关注专栏   写文章     圣诞丨太阁所有的免费算法视频资料整理 Ray Cao· 12 小时前 感谢大家一年以来对太阁实验室的支持,我们特地整理了在过去一年中我们所有的原创算法 ...

  4. 代码生成器Kalman Studio2.2发布,完美支持Oracle,不需要安装Oracle客户端

    这次更新主要是增加对Oracle的支持,不需要安装Oracle客户端,下面的配置文件列出了Kalman Studio支持的几种数据库 <?xml version="1.0" ...

  5. Mac工具

    iterm2是一个替代终端和iTerm的后继项目.它支持 OS 10.5 或者更新版本.iterm2 提供更多你需要的功能和特点. Flashlight,快速且全面地显示所有「关键词」索引出的结果 参 ...

  6. WPF 模板

    一.DataTemplate(数据模板)1.引用命名空间xmlns:别名="clr-namespace:命名空间" 2.调用命名空间下的类别和属性<Window.Resour ...

  7. Swift基础--手势识别(双击、捏、旋转、拖动、划动、长按)

    // //  ViewController.swift //  JieUITapGestureRecognizer // //  Created by jiezhang on 14-10-4. //  ...

  8. iOS开发——高级技术精选&底层开发之越狱开发第二篇

    底层开发之越狱开发第二篇 今天项目中要用到检查iPhone是否越狱的方法. Umeng统计的Mobclick.h里面已经包含了越狱检测的代码,可以直接使用 /*方法名: * isJailbroken ...

  9. 部署tomcat在windows服务器下,将tomcat控制台日志记录到日志文件中

    在Linux系统中,Tomcat 启动后默认将很多信息都写入到 catalina.out 文件中,我们可以通过tail  -f  catalina.out 来跟踪Tomcat 和相关应用运行的情况. ...

  10. IOS Application Security Testing Cheat Sheet

    IOS Application Security Testing Cheat Sheet    [hide]  1 DRAFT CHEAT SHEET - WORK IN PROGRESS 2 Int ...