iOS-验证码倒计时60秒
一. 要求
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秒的更多相关文章
- js 验证码 倒计时60秒
js 验证码 倒计时60秒 <input type="button" id="btn" value="免费获取验证码" /> & ...
- vue实现验证码倒计时60秒的具体代码
vue实现验证码倒计时60秒的具体代码 <span v-show="show" @click="getCode">获取验证码</span> ...
- jQuery实现发送验证码倒计时60秒
前端HMTL: <div class="form_box"> <div class="line mb40"> <div class ...
- javaScript 验证码 倒计时60秒
<input type="button" id="btn" value="免费获取验证码" /> <script type ...
- Android 实现简单 倒计时60秒,一次1秒
倒计时功能如上图所示,其实就几行代码即可实现效果啦!!! /** 倒计时60秒,一次1秒 */ CountDownTimer timer = new CountDownTimer(60*1000, 1 ...
- js实现倒计时60秒的简单代码
<!DOCTYPE html> <html lang="en"> <head> <meta http-equiv="Conten ...
- js 简单实现获取短信按钮倒计时60秒
<!DOCTYPE html><html lang="en"><head> <meta http-equiv="Content- ...
- Jquery插件实现点击获取验证码后60秒内禁止重新获取
通过jquery.cookie.js插件可以快速实现“点击获取验证码后60秒内禁止重新获取(防刷新)”的功能 先到官网(http://plugins.jquery.com/cookie/ )下载coo ...
- jQuery实现发送短信验证码后60秒倒计时
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script sr ...
随机推荐
- Speech两种使用方法
COM组件使用speech: public class Speach { private static Speach _Instance = null ; private SpeechLib.SpVo ...
- Entity Framework Code First迁移基本面拾遗
项目中用到了EF Code First和迁移,但发现有些方面似懂非懂.比如:如何在迁移文件中控制迁移过程?如果在迁移文件中执行SQL语句?如何使用Update-Database的其它参数?数据库在生产 ...
- old header
海纳百川 山不拒土 No Backspace in Real Life. Love Life![Cloud][LBS][GIS][GPS][MAPS][C++][Java]
- 自定义 scrapy 爬虫的 requests
之前使用 scrapy 抓取数据的时候 ,默认是在逻辑中判断是否执行下一次请求 def parse(self): # 获取所有的url,例如获取到urls中 for url in urls: yiel ...
- Mysql数据备份与恢复
REM INIT→既に指定したファイルが有った場合, 上書きする REM NORECOVERY→接続先データベースへの既存の接続を閉じる REM REPLACE→既存のデータベースを上書きする set ...
- JavaScriptSerializer 中的匿名类型 转json
二:JavaScriptSerializer 中的匿名类型 这个类型我想大家都清楚,不过性能更高的方式应该是用JsonConvert吧,但这个不是本篇讨论的话题,我们重点来看看匿名类型的Json序列化 ...
- MYSQL校对规则
一.前言 有时候遇到这种情况,你用一个like语句查询,查到的结果中有一些并没有包含你查询的关键词的纪录:有时候遇到这种情况,你的数据库自作聪明的大小写不敏感,让你在更新时把大小写不同的两条记录都更新 ...
- Carthage 安装和使用
和Cocoapods相比各有利弊吧,具体对比参见: Carthage 初探:四大优势与四大劣势 第一步:如果没有安装Homebrew先安装 打开命令终端,直接输入以下命令回车 /usr/bin/rub ...
- 【汇总】iOS开发及Xcode使用中遇到的一些报错问题汇总
这里整合下在开发过程中遇到过的一些报错问题和解决办法:(今天开始逐渐增加) Xcode编译错误集锦:http://www.cnblogs.com/ios-wmm/p/3402261.html ...
- Android中GridView使用总结
1.http://blog.csdn.net/hellogv/article/details/4567095 基础篇,GridView最基本的用法 2.http://my.eoe.cn/cainia ...