计时按钮TimerButton

最近的项目中总是用到计时发送验证码的按钮,虽然很容易实现,但是一遍遍写handler也是挺麻烦的,所以打算封装一下造个轮子,方便以后使用;


对于封装这个控件,我的想法是首先从需求出发,我需要一个计时控件,如何实现该功能,需要什么样的功能出发的,下面开始;

1,我使用handler发送消息的方式来实现计时;

2,提供了正序和逆序的计时方式;

3,提供了计时时长的设置;

4,提供了每一秒的回调和计时开始,计时结束的回调(已经封装了onclickListener)

下面看代码,代码中我都写了很详细的注释了很容易看懂。

import android.content.Context;
import android.os.Handler;
import android.os.Message;
import android.util.AttributeSet;
import android.view.View;
import android.widget.Button;

import java.util.Timer;
import java.util.TimerTask;

/**
 * 项目中经常遇到短信验证等计时的button,特此封装一个timerButton类
 * 1-provide duration setting
 * -提供计时时长设置
 * 2-provide forward and reverse timing mode,default reverse mode;
 * -提供正序和逆序计时,默认逆序倒数计时
 * 3-provide timing start callback,it receive a variable of boolean type to decide whether response onClick event this time;
 * -提供计时开始回调,接收布尔值,return true则点击开始计时;return false则不开始,用于一些场景业务逻辑的判断需要,比如两次输入密码是否一致后发送验证码
 * 4-provide timing finish callback
 * -提供计时完成回调onTimeFinish
 * 5-provide every second callback
 * -提供每一秒计时回调onEverySecond
 * 6-provide public method to control start and cancel
 * -提供开始计时和结束计时方法
 * How to use
 * -1,setTimerDuration;2,.autoMode() or .manusalMode();3,setOnEverySecondeLIstener;
 * -使用方法:1,setTimerDuration;2,autoMode(自动或手动)
### 创建点击按钮启动计时器的 React 组件 为了实现在 React 中通过点击按钮来启动计时器的功能,可以遵循如下方法。首先,初始化一个新的 React 应用程序可以通过 `npx create-react-app` 来完成[^1]。 一旦项目建立完毕,在应用程序的主要组件文件中引入必要的依赖项并编写逻辑代码: ```jsx import React, { useState, useEffect } from 'react'; function TimerButton() { const [timeLeft, setTimeLeft] = useState(0); const [isRunning, setIsRunning] = useState(false); useEffect(() => { let intervalId; if (isRunning && timeLeft > 0) { intervalId = setInterval(() => { setTimeLeft((prevTime) => prevTime - 1); }, 1000); } return () => clearInterval(intervalId); // 清除定时器防止内存泄漏 }, [isRunning, timeLeft]); const startTimer = (durationInSeconds) => { setTimeLeft(durationInSeconds); setIsRunning(true); }; const stopTimer = () => { setIsRunning(false); }; return ( <div> <button onClick={() => startTimer(60)}>Start Timer</button> {/* 设置倒计时时长 */} <p>{timeLeft} seconds remaining</p> {isRunning ? ( <button onClick={stopTimer}>Stop Timer</button> ) : null} </div> ); } export default TimerButton; ``` 上述代码展示了如何创建一个简单的计时器功能,其中包含了两个状态变量用于追踪剩余时间和当前计时器的状态(运行与否)。每当用户点击 "Start Timer" 按钮时,会触发 `startTimer()` 方法,并传入想要倒计时的时间长度作为参数;而当再次按下停止按钮,则调用了 `stopTimer()` 方法使计时暂停[^4]。 此示例还利用了 `useEffect` 钩子来处理副作用操作——即设置和清除 JavaScript 的内置 `setInterval` 定时器函数,从而实现了每秒更新一次显示时间的效果。此外,注意清理工作的重要性以避免潜在的问题如内存泄露等[^5]。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值