自定义包含天时分的时长选择器组件

news2024/10/6 4:02:14

场景:项目是react+antd 实现的。如果传感器超过3天4小时没有上报数据,则认为设备已经坏了,需要发出告警。 3天4小时这是由用户在前端页面输入的,因此需要有一个时长选择器。antd 原生的TimePicker 组件只能实现选择 时、分、秒,不符合我项目场景中需要最长7天的需求。
TimePicker

因此基于antd 的 原生组件 封装自定义了新的组件。

你可以使用 Ant Design 的 TimePicker 组件和 InputNumber 组件来实现时长选择器,可以选择天、时、分的时长。具体实现方式如下:

import { TimePicker, InputNumber } from 'antd';
import moment from 'moment';
import { useState } from 'react';

function DurationPicker() {
  const [days, setDays] = useState(0);
  const [hours, setHours] = useState(0);
  const [minutes, setMinutes] = useState(0);

  const handleDaysChange = value => {
    setDays(value);
  };

  const handleHoursChange = value => {
    setHours(value);
  };

  const handleMinutesChange = value => {
    setMinutes(value);
  };

  const handleTimeChange = (time, timeString) => {
    setHours(parseInt(timeString.split(':')[0]));
    setMinutes(parseInt(timeString.split(':')[1]));
  };

  const handleBlur = () => {
    setDays(Math.min(Math.max(days, 0), 30));
    setHours(Math.min(Math.max(hours, 0), 23));
    setMinutes(Math.min(Math.max(minutes, 0), 59));
  };

  const duration = moment.duration({
    days,
    hours,
    minutes,
  });

  return (
    <div>
      <InputNumber
        min={0}
        max={30}
        defaultValue={0}
        onChange={handleDaysChange}
        onBlur={handleBlur}
      /><InputNumber
        min={0}
        max={23}
        defaultValue={0}
        onChange={handleHoursChange}
        onBlur={handleBlur}
      />
      小时
      <InputNumber
        min={0}
        max={59}
        defaultValue={0}
        onChange={handleMinutesChange}
        onBlur={handleBlur}
      />
      分钟
      <TimePicker
        format="HH:mm"
        defaultValue={moment('00:00', 'HH:mm')}
        onChange={handleTimeChange}
      />
      <div>总时长:{duration.humanize()}</div>
    </div>
  );
}

在这个示例中,我们首先从 antd 中导入了 TimePickerInputNumber 组件,以及 moment 库和 useState 钩子函数。然后,我们使用 useState 钩子函数定义了三个状态变量 dayshoursminutes,分别表示选择的天数、小时数和分钟数。我们还定义了三个回调函数 handleDaysChangehandleHoursChangehandleMinutesChange,分别用于处理天数、小时数和分钟数的变化事件。在这些回调函数中,我们使用 setDayssetHourssetMinutes 函数来更新状态变量的值。

接下来,我们定义了一个回调函数 handleTimeChange,用于处理时间的变化事件。在这个回调函数中,我们使用 parseInt 函数来将时间字符串解析为整数,并分别更新小时数和分钟数的状态变量的值。

然后,我们定义了一个回调函数 handleBlur,用于限制天数、小时数和分钟数的范围。在这个回调函数中,我们使用 Math.minMath.max 函数来限制变量的值在指定范围内。最后,我们使用 moment.duration 函数创建了一个时长对象 duration,表示选择的总时长。我们在组件中返回了四个 InputNumber 组件和一个 TimePicker 组件,以及一个显示总时长的文本。

需要注意的是,在使用 InputNumber 组件时,需要安装 antd 库。可以使用以下命令安装 antd 库:

npm install antd

或者使用以下命令安装 antd 库的 TypeScript 类型定义:

npm install @types/antd

在使用 moment 库时,需要安装 moment 库和 moment-duration-format 库。可以使用以下命令安装这些库:

npm install moment moment-duration-format

或者使用以下命令安装这些库的 TypeScript 类型定义:

npm install @types/moment @types/moment-duration-format

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/650796.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

(Qt)day4

widget.h #ifndef WIDGET_H #define WIDGET_H#include <QDebug> #include <QMainWindow> #include <QMessageBox> #include <QTimer> //定时器类头文件 #include <QTime> //时间类的头文件 #include <QTimerEvent> //定时器…

k8s的service资源类型有ClusterIP、Nodeport、ExternalName、LoadBalancer、Headless(None)

1. ClusterIP 是什么 ClusterIP 是在所有节点内生成一个虚拟IP&#xff0c;为一组pod提供统一的接入点&#xff0c;当service存在时&#xff0c;它的IP地址和端口不会发生改变&#xff0c;客户端通过service的ip和端口建立连接&#xff0c;由service将连接路由到该服务的任意一…

基于深度学习的人脸识别与检测方案

一、项目介绍前言 人脸识别作为一种生物特征识别技术&#xff0c;具有非侵扰性、非接触性、友好性和便捷性等优点。人脸识别通用的流程主要包括人脸检测、人脸裁剪、人脸校正、特征提取和人脸识别。人脸检测是从获取的图像中去除干扰&#xff0c;提取人脸信息&#xff0c;获取人…

使用ASM在Android中进行字节码注入

目录 使用方法 1.编译使用插件 这里自定义了一个插件用来对字节码进行操作 首先我们需要找到这个Gradle任务&#xff0c;双击进行编译打包 打包成功后会生成如下目录 然后我们需要在项目的gradle文件中进行引用 然后在application的model下的gradle中应用插件 2.使用ASM清…

【裸机开发】中断系统(二)—— Reset 中断服务函数(汇编实现)

目录 一、Reset 中断服务函数的实现步骤 二、汇编实现 Reset 中断服务函数 1、禁止/打开全局中断 2、设置SP指针 3、清除 .bss 段 4、完整 Reset 中断服务函数 一、Reset 中断服务函数的实现步骤 实现 Reset 中断服务函数的基本步骤如下&#xff1a; 设置各个模式下的S…

发布Android Lib 到 MavenCentral

新建 Sonatype 项目 注册账号&#xff1a; https://issues.sonatype.org/secure/Signup!default.jspa 这里注册不需要什么验证码&#xff0c;很简单。 创建问题 点击新建&#xff1a; 概要&#xff1a;自定义&#xff0c;写项目名称即可。 GroupId&#xff1a;如果是git…

C语音:打印整数二进制的奇数位和偶数位

题目&#xff1a; 获取一个整数二进制序列中所有的偶数位和奇数位&#xff0c;分别打印出二进制序列 思路&#xff1a; 总体思路&#xff1a; &#xff08;一&#xff09;. 输入数据 &#xff08;二&#xff09;. 打印奇数位&#xff1a; 使用 for循环 循环产生 1~32 之间的偶…

2023年5月 青少年软件编程(图形化) 等级考试试卷(一级)

青少年软件编程&#xff08;图形化&#xff09; 等级考试试卷&#xff08;一级&#xff09;2023.6 一、 单选题(共 25 题&#xff0c; 共 50 分) 1.看图找规律&#xff0c; 请问下图红框中是&#xff1f; &#xff08; &#xff09; A. B. C. D. 标准答案&#xff1a; D 试题解…

centos系统把.net6 web api部署到docker

为了搞定docker是怎么部署的&#xff0c;做个笔记 前提条件准备一个core项目,使用vs自带的docker打包假如你选择docker支持的时候不小心安装了Docker Desktop&#xff1b;还可以简单的先部署到本地docker中发布到centosdocker常用命令 前提条件 一台centos 8.0 版本以上的linu…

软件测试的7年,我秃了,也变强了...

当前就业环境&#xff0c;裁员、失业消息满天飞&#xff0c;好像能有一份工作就不错了&#xff0c;更别说高薪。其实这只是一方面。另一方面&#xff0c;各大企业依然求贤若渴&#xff0c;高技术人才依然紧缺&#xff0c;只要技术过硬&#xff0c;拿个年包50w不是问题。 人生格…

i.MX RT1010跨界MCU(MCUXpresso IDE上手体验)

MCUXpresso IDE是专为NXP半导体的基于ARM Cortex-M内核的MCU芯片开发而设计的&#xff0c;其优势主要体现在以下几个方面&#xff1a; MCUXpresso IDE集成了MCUXpresso SDK&#xff0c;这是NXP提供的一个软件开发套件&#xff0c;包含了底层驱动、中间件以及大量的示例代码和应…

Charles Windows10使用 证书安装 过期重设 证书加入到受信任根目录 配置访问WhatsApp

普通教程文档 抓包神器 Charles 使用教程详解 - 知乎 界面选项详细讲解 Charles的功能介绍与使用教程&#xff0c;一学就会&#xff0c;不信就来试试&#xff1f; 疑难杂症 由于CA 根证书不在“受信任的根证书颁发机构”存储区中&#xff0c;所以它不受信任 1、winr 运行…

SandQuant停止运营,免费获取A股数据

亲爱的各位朋友们&#xff1a; SandQuant即日起不再对外提供任何服务&#xff0c;为了感恩曾经支持过我们的客户朋友&#xff0c;现免费提供所有A股数据&#xff08;数据非常庞大&#xff0c;请酌情下载&#xff09;&#xff0c;请通过链接自取。 请关注我们获取链接&#xff…

产品不可或缺的文档——帮助文档

在互联网时代&#xff0c;产品的更新迭代速度越来越快&#xff0c;产品功能也越来越复杂&#xff0c;为了让用户能够更好地理解和使用产品&#xff0c;帮助文档逐渐成为了产品不可或缺的一部分。本文将从帮助文档的作用、设计原则、撰写技巧等方面探讨帮助文档的重要性及如何编…

【AI面试】损失函数(Loss),定义、考虑因素,和怎么来的

神经网络学习的方式,就是不断的试错。知道了错误,然后沿着错误的反方向(梯度方向)不断的优化,就能够不断的缩小与真实世界的差异。 此时,如何评价正确答案与错误答案,错误的有多么的离谱,就需要一个评价指标。这时候,损失和损失函数就运用而生。 开始之前,我们先做…

MySQL数据库——初步安装与数据表结构数据管理

MySQL数据库——初步安装与数据表结构数据管理 一、数据库的基本概念1.数据库基本常识2.数据库系统发展史 二、数据库的分类1.关系数据库&#xff08;SQL&#xff09;2.非关系数据库&#xff08;NO SQL&#xff09; 三、mysql的数据类型1.常用的数据库类型2.char与varchar的区别…

ijkplayer 支持srt协议 rtmp协议编译步骤

写在前面 ffafaf这个编译真的太垃圾了 一堆毛病 感受下webrtc 傻瓜式编译 环境首先必须ndk 是android-ndk-r15c 或者 android-ndk-r14b ubuntu 系统随便22或者20&#xff0c;18都行 有个非常重要的点python必须是2.7 不然你会看到一大堆报错 高版本的ubuntu默认都是python3…

回溯算法基本思想及其实现

文章目录 基本思想回溯算法的递归框架组合问题组合总和组合去重子集全排列 基本思想 回溯算法是一种递归算法&#xff0c;它试图通过尝试不同的选择&#xff0c;解决一个问题。它的基本思想是从可能的决策开始搜索&#xff0c;如果发现这条路往下走不能得到有效的解答&#xf…

12-事件模型(也就是一个先后触发顺序)

一、事件与事件流 HTML文档、浏览器中发生的一种交互。使得具备互动性&#xff0c;加载、鼠标、自定义事件。 由于DOM是一个树结构&#xff0c;意味着标签存在嵌套关系&#xff0c;当绑定事件的时候&#xff0c;当触发子节点的时候&#xff0c;一个顺序问题&#xff0c;概念-事…

人机交互学习-4 交互设计过程

交互设计过程 交互设计过程基本活动关键特征 设计过程中的问题如何选取用户&#xff1f;如何明确需求&#xff1f;如何提出候选方案&#xff1f;如何在候选方案中选择&#xff1f; 交互设计生命周期模型星型生命周期模型可用性工程生命周期模型 交互设计过程管理界面设计的4个支…