iOS按钮倒计时

#pragma mark---获取验证码

///获取验证码

-(void)startTime{

    __block int timeout=59; //倒计时时间

    dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);

    dispatch_source_t _timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0,queue);

    dispatch_source_set_timer(_timer,dispatch_walltime(NULL, 0),1.0*NSEC_PER_SEC, 0); //每秒执行

    dispatch_source_set_event_handler(_timer, ^{

        if(timeout<=0){ //倒计时结束,关闭

            dispatch_source_cancel(_timer);

            dispatch_async(dispatch_get_main_queue(), ^{

                //设置界面的按钮显示 根据自己需求设置

                [_CodeBtn setTitle:@"获取验证码" forState:UIControlStateNormal];

                _CodeBtn.userInteractionEnabled = YES;

            });

        }else{

            //            int minutes = timeout / 60;

            int seconds = timeout % 60;

            NSString *strTime = [NSString stringWithFormat:@"%.2d", seconds];

            dispatch_async(dispatch_get_main_queue(), ^{

                //设置界面的按钮显示 根据自己需求设置

                [_CodeBtn setTitle:[NSString stringWithFormat:@"%@秒后重发",strTime] forState:UIControlStateNormal];

                _CodeBtn.userInteractionEnabled = NO;

                

            });

            timeout--;

            

        }

    });

    dispatch_resume(_timer);

    

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
UniApp 是一个基于 Vue.js 的跨平台框架,它允许开发者用一套代码构建同时运行在微信小程序、H5、App(iOS/Android)等平台的应用。关于一分钟计时功能,你可以使用 UniApp 提供的 timer 或者 custom component 来实现。以下是一个简单的示例: ```html <template> <view> <button @click="startTimer">开始计时</button> <text v-if="isRunning" :value="remainingTime">计时:{{ remainingTime }}</text> </view> </template> <script> export default { data() { return { isRunning: false, remainingTime: '00:01', }; }, methods: { startTimer() { this.isRunning = true; const intervalId = setInterval(() => { if (this.remainingTime.split(':') > 0) { this.remainingTime = this.formatTime(this.subtractSeconds(this.remainingTime, 1)); } else { this.stopTimer(); this.$message('计时结束!'); } }, 1000); // 在组件卸载前关闭计时器,避免内存泄漏 this.$onBeforeDestroy(() => clearInterval(intervalId)); }, stopTimer() { this.isRunning = false; }, subtractSeconds(timeStr, seconds) { const [hours, minutes] = timeStr.split(':'); const newMinutes = parseInt(minutes) - seconds; if (newMinutes < 0) { newMinutes += 60; hours--; } return `${(hours < 10 ? '0' : '')}${hours}:${(newMinutes < 10 ? '0' : '')}${newMinutes}`; }, formatTime(time) { return `${time.split(':')}:${time.split(':')}`; }, }, }; </script> ``` 在这个例子中,我们创建了一个计时,点击后开始计时,每秒减少一秒,直到时间为0。`formatTime` 和 `subtractSeconds` 函数用于处理时间格式和减法操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值