【React】TimePicker进阶:解决开始时间可大于结束时间的业务场景与禁止自动排版

目录


前言

该例子框架为React + TypeScript + Ant Design

📢注意:

本文使用React 18+和Ant Design 5.x版本

需要预先安装dayjs处理日期时间

示例包含完整的类型定义和实时显示功能


提示:以下是本篇文章正文内容,下面案例可供参考

一、实现步骤

完整示例

typescript 复制代码
import React, { useState } from "react";
import ReactDOM from "react-dom/client";
import { TimePicker, Card, Typography } from "antd";
import type { Dayjs } from "dayjs";
import "antd/dist/reset.css";

const { RangePicker } = TimePicker;
const { Text } = Typography;

const App = () => {
  const [timeRange, setTimeRange] = useState<
    [Dayjs | null, Dayjs | null] | null
  >(null);

  const handleChange = (times: [Dayjs | null, Dayjs | null] | null) => {
    setTimeRange(times);

    if (times && times[0] && times[1]) {
      console.log(
        "选择的时间段:",
        times[0].format("HH:mm"),
        "至",
        times[1].format("HH:mm")
      );
    }
  };

  return (
    <div style={{ padding: 24 }}>
      <Card title="时间范围选择器(带校验)" style={{ width: 400 }}>
        <RangePicker
          value={timeRange}
          onChange={handleChange}
          format="HH:mm"
          placeholder={["开始时间", "结束时间"]}
          order={false}
        />

        {timeRange && timeRange[0] && timeRange[1] && (
          <div style={{ marginTop: 16 }}>
            <Text>
              选择的时间段: {timeRange[0].format("HH:mm")} -{" "}
              {timeRange[1].format("HH:mm")}
            </Text>
          </div>
        )}

        <Text type="secondary" style={{ display: "block", marginTop: 8 }}>
          尝试选择开始时间大于结束时间,组件会自动调整顺序
        </Text>
      </Card>
    </div>
  );
};

// 渲染到DOM
const root = ReactDOM.createRoot(
  document.getElementById("root") as HTMLElement
);
root.render(<App />);

export default App;

二、主要核心

主要解决问题的核心点是,在AntDesign组件RangePicker中有一个属性:order={false}

相关推荐
杨超凡19 分钟前
豆包收费了?我特么自己用“意念”搓了一个!
javascript
threelab1 小时前
Three.js 咖啡杯烟雾效果 | 三维可视化 / AI 提示词
开发语言·javascript·人工智能
Heo1 小时前
14_React 中的更新队列 updateQueue
前端·javascript·面试
前端 贾公子2 小时前
解决浏览器端 globalThis is not defined 报错
前端·javascript·vue.js
之歆2 小时前
DAY12_CSS3选择器全攻略 + 盒子新特性完全指南(下)
前端·javascript·css3
kyriewen112 小时前
代码写成一锅粥?3个设计模式让你的项目“起死回生”
开发语言·前端·javascript·设计模式·ecmascript
郑生zs2 小时前
Hooks-useEffect
react.js
光影少年2 小时前
react函数组件、类组件、纯组件、受控/非受控组件
前端·react.js·掘金·金石计划
iCxhust3 小时前
在 emu8086 中可以直接编译运行的完整汇编程序,演示数组的定义、遍历、求和、求最大值。
开发语言·前端·javascript·汇编·单片机·嵌入式硬件·算法
JianZhen✓3 小时前
2026前端高频面试题总结(Vue/JS/网络/Webpack/性能优化/手写)
前端·javascript·vue.js