返回顶部
首页 > 资讯 > 精选 >React怎么实现一个倒计时hook组件
  • 448
分享到

React怎么实现一个倒计时hook组件

2023-07-05 05:07:41 448人浏览 薄情痞子
摘要

这篇“React怎么实现一个倒计时hook组件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“React怎么实现一个倒计时ho

这篇“React怎么实现一个倒计时hook组件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“React怎么实现一个倒计时hook组件”文章吧。

思路

倒计时可能需要显示剩余时间的单位有:天、时、分、秒、毫秒,可能只需显示一个,也可能都需要显示。

注意细节:

  • 只显示某一单位的时间或者需要显示的最大单元时间,需要可以大于正常时间最大限制,比如要剩余 100 小时 58 分时,小时需要可以大于 23,分钟不能大于 59 。

  • 需要可以设置是否显示毫秒,1s等于1000ms,但人的反应时间是0.2s~0.3s,因此毫秒以百为单位显示,显示毫秒适用于秒杀类活动场景。

实现

先来定义好参数:

export interface CountDownOptions {    deadlineTime: number;    showMillisecond?: boolean;}

参数只需要倒计时截止时间以及是否需要显示毫秒。

再定义一下需要获取的返回值:

export interface TimeInfo {    day: number;    hours: number;    hoursStr: string;    minutes: number;    minutesStr: string;    seconds: number;    secondsStr: string;    milliseconds?: number;    millisecondsStr?: string;    end: boolean;}

dayhoursminutessecondsmilliseconds 都是剩余的多少秒数,没有做限制,hoursStrminutesStrsecondsStrmillisecondsStr 才做限制,比如剩下 1天10小时10分钟10秒100毫秒,那么显示结果如下:

{    day,    hours,    hoursStr,    minutes,    minutesStr,    seconds,    secondsStr,    end: false,  }

下面来看具体实现代码。

先实现一个简单的补零函数,js字符串本身也有补零函数,也可以直接使用的,不过也需要转换类型。

// 格式化数据,这里就是补零function fORMate(time: number): string {  return `${time < 10 ? "0" : ""}${time}`;}

工具方法——清除倒计时数据数据信息:

function clearCountdownInfo(showMillisecond = false): TimeInfo {  const timeInfo: TimeInfo = {    day: 0,    hours: 0,    hoursStr: "00",    minutes: 0,    minutesStr: "00",    seconds: 0,    secondsStr: "00",    end: true,  };  if (showMillisecond) {    timeInfo.milliseconds = 0;    timeInfo.millisecondsStr = "0";  }  return timeInfo;}

关键工具方法——计算倒计时返回的数据信息:

function computeCountdownInfo(  remainTime: number,  showMillisecond = false): TimeInfo {  // 剩余时间小于说明结束,直接清空  if (remainTime < 0) {    return clearCountdownInfo(showMillisecond);  }  // 这里用了一个比较笨的方法,一个个进行计算,后续可以优化试试看  const day = Math.floor(remainTime / (24 * 60 * 60));  const hours = Math.floor((remainTime / (60 * 60)) % 24);  const hoursStr = formate(hours);  const minutes = Math.floor((remainTime / 60) % 60);  const minutesStr = formate(minutes);  const seconds = Math.floor(remainTime % 60);  const secondsStr = formate(seconds);  // 组合成需要返回的时间信息  const timeInfo: TimeInfo = {    day,    hours,    hoursStr,    minutes,    minutesStr,    seconds,    secondsStr,    end: false,  };  // 需要显示毫秒逻辑处理  if (showMillisecond) {    const milliseconds = Math.floor(remainTime * 1000);    // 只取首位    const millisecondsStr = String(milliseconds).slice(-3);    timeInfo.milliseconds = milliseconds;    timeInfo.millisecondsStr = millisecondsStr;  }  return timeInfo;}

核心逻辑 &mdash;&mdash; useCountdown hook 组件:

export const useCountdown = (options: CountDownOptions) => {  // 首次初始化数据,显示清除的数据  const [timeInfo, setTimeInfo] = useState<TimeInfo>(    clearCountdownInfo(options.showMillisecond)  );  useEffect(() => {    let timer = 0;    function countdown() {      const remainTime = computeRemainTime(options.deadlineTime);      // 剩余时间大于 0 才开始倒计时      if (remainTime > 0) {        // 未结束时直接定时下一次在执行判断 countdown        timer = window.setTimeout(          countdown,          options.showMillisecond ? 100 : 1000 // 毫秒级则修改定时器时间        );      }      const data = computeCountdownInfo(remainTime, options.showMillisecond);      setTimeInfo(data);    }    // 开始倒计时    countdown();    return () => {      // 清除定时器      timer && clearInterval(timer);    };  }, [options.deadlineTime, options.showMillisecond]);  return timeInfo;};

上面需要注意一下,服务端渲染的情况不要首次进行render的时候初始化数据,会和服务端已经不一致导致 hydrate 报错。

客户端渲染的可以在render的时候初始化代码:

// 渲染时获取一次剩余时间const remainTime = useMemo(    () => computeRemainTime(options.deadlineTime),    [options.deadlineTime]);// 首次初始化数据,以防页面闪烁const [timeInfo, setTimeInfo] = useState<TimeInfo>(    computeCountdownInfo(remainTime));

以上就是关于“React怎么实现一个倒计时hook组件”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

--结束END--

本文标题: React怎么实现一个倒计时hook组件

本文链接: https://lsjlt.com/news/349758.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • React怎么实现一个倒计时hook组件
    这篇“React怎么实现一个倒计时hook组件”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“React怎么实现一个倒计时ho...
    99+
    2023-07-05
  • React实现一个倒计时hook组件实战示例
    目录前言思路实现总结前言 本篇文章主要实现一个无样式的倒计时 hook 组件,通常不同地方的倒计时样式都不同,但倒计时的逻辑基本是都是一样的,因此可以抽离成一个工具方法或者一个 ...
    99+
    2023-02-23
    React倒计时hook组件 React hook
  • React+Typescript实现倒计时Hook的方法
    首先对setInterval做了Hook化封装👇 import { useEffect, useRef } from 'react' function us...
    99+
    2024-04-02
  • React如何实现倒计时组件
    这篇文章将为大家详细讲解有关React如何实现倒计时组件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。倒计时组件&mdash;&mdash;需求描述:写一个函数式组件CountDown,设...
    99+
    2023-06-29
  • 利用Android设计一个倒计时组件
    目录1 背景2 对比分析2.1 是否是倒计时2.2 支持多任务2.3 支持时间校准2.4 支持同帧刷新2.5 支持延迟执行2.6 支持CPU休眠3 需求目标4 设计类结构5 具体实现...
    99+
    2024-04-02
  • 利用React-Native怎么实现一个验证码倒计时按钮
    利用React-Native怎么实现一个验证码倒计时按钮?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。开发过程中有获取手机验证码的场景,这时候有这样的要求:1,点击“获取验证码...
    99+
    2023-05-31
    react native
  • 小程序倒计时组件怎么实现
    本篇内容主要讲解“小程序倒计时组件怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“小程序倒计时组件怎么实现”吧!  介绍:  用于在微信小程序中进行倒计时的组件。  功能:  1、最基础的...
    99+
    2023-06-26
  • React Hook实现对话框组件
    React Hook实现对话框组件,供大家参考,具体内容如下 准备 思路:对话框组件是有需要的时候希望它能够弹出来,不需要的时候在页面上是没有任何显示的,这就意味着需要一个状态,在父...
    99+
    2024-04-02
  • JavaScript中怎么实现一个倒数计时器
    本篇文章给大家分享的是有关JavaScript中怎么实现一个倒数计时器,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。有时,您将需要构建一个Ja...
    99+
    2024-04-02
  • Android中怎么实现一个倒计时效果
    今天就跟大家聊聊有关Android中怎么实现一个倒计时效果,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。需求:a.在后台添加时,如果是今日直播,则需要添加开始时间(精确到秒);b.离...
    99+
    2023-05-30
    android
  • Android实现一个倒计时自定义控件
    目录(一)前言(二)效果展示(三)实现思路(三)代码地址总结(一)前言 Android 其实提供了一个倒计时控件叫做CountDownTimer,这个倒计时控件用起来也很简单,但是要...
    99+
    2024-04-02
  • vue实现秒杀倒计时组件
    本文实例为大家分享了vue实现秒杀倒计时组件的具体代码,供大家参考,具体内容如下 下面是使用Vue实现秒杀倒计时组件 开发思路 1.请求服务器获取这一刻的服务器时间(统一以服务器时...
    99+
    2024-04-02
  • 利用momentJs做一个倒计时组件(实例代码)
    今天抽空给大家介绍下vue和moment做的一个倒计时,具体内容如下所示: 展示样式: <template> <div class="table-ri...
    99+
    2024-04-02
  • 如何利用momentJs做一个倒计时组件
    今天就跟大家聊聊有关如何利用momentJs做一个倒计时组件,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。vue和moment做的一个倒计时展示样式:<template>...
    99+
    2023-06-22
  • 使用vue怎么实现一个倒计时功能
    这期内容当中小编将会给大家带来有关使用vue怎么实现一个倒计时功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。通过父组件传入的结束时间减去当前日期得到剩余时间子组件部分<div clas...
    99+
    2023-06-14
  • 利用java怎么实现一个倒计时功能
    这期内容当中小编将会给大家带来有关利用java怎么实现一个倒计时功能,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。代码如下:package timer;import java.util.Calendar;...
    99+
    2023-05-31
    java ava
  • 怎么在Android中实现一个倒计时功能
    本篇文章给大家分享的是有关怎么在Android中实现一个倒计时功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。以30分钟为例写的一个倒计时:public class Main...
    99+
    2023-05-31
    android roi %d
  • vue如何设计一个倒计时秒杀的组件
    这篇文章将为大家详细讲解有关vue如何设计一个倒计时秒杀的组件,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。简介:倒计时秒杀组件在电商网站中层出不穷  不过思路...
    99+
    2024-04-02
  • React Native 中实现倒计时功能
    目录正文首次实现最终实现示例正文 在 React Native,该如何实现一个倒计时功能呢? 首次实现 表面看来很简单,譬如像下面这样: const timer = useRef&...
    99+
    2022-11-13
    React Native倒计时 React Native
  • 使用react怎么实现一个Radio组件
    使用react怎么实现一个Radio组件?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。测试组件:class Test extends Comp...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作