React 会议时段拖拽选择组件开发

前提:

类似企微会议选择的功能,之前的选择需要用户对会议时间段一个个的点击进行选择,操作非常繁琐,期望达到企微拖拽选择的一个效果。

目前的效果:

期望效果:

现在的功能是将一天的时间分为24个时间段,每个时间段又分成两个半小时,每半小时为一个最小单位,用户可以对这个单位的进行时间的占用操作。

在搜索之后并没有找到 React 相关的开源组件,于是借助了于 AntdSlider 组件的 range 功能去实现。

思路

Slider 组件的步进值设置为 100 / 48

点击某个时间块,根据下标获取当前的范围,作为初始值赋值给 Slider, 并显示组件(对组件的样式进行了一些修改,组件父容器为一整天的时间元素)

javascript 复制代码
const STEP = 100 / 48;

const [timeArea, setTimeArea] = useState<Array<number>>([]); // Slider组件值
const [controllerVisible, setControllerVisible] = useState(false);

// 根据点击区块的下标获取 Slider 组件的 value
const getTimeArea = (index: number) => {
    const area = [index * STEP, (index + 1) * STEP];
    setTimeArea(area);
}

const handleTimeClick = (item: TimeItem, index: number) => {
    getTimeArea(index);
    setControllerVisible(true);
};

const handleSliderChange = (value: Array<number>) => {
    setTimeArea(value);
};

// 获取已选择的时间段下标范围
const getSelectedIndexRange = () => {
    let leftIndex = Math.floor(timeArea[0] / STEP);
    const indexRange: Array<number> = [
      leftIndex,
      Math.floor(timeArea[1] / STEP ) - 1,
    ];
    
    return indexRange
}

return ( 
    <div>
        // ...
        <Slider
            style={{ display: controllerVisible ? "block" : "none" }}
            range
            step={STEP}
            value={timeArea}
            tooltip={{ open: false }}
            onChange={handleSliderChange}
            onAfterChange={handleAfterChange}
        />
        // ...
    </div>
)
css 复制代码
.ant-slider-rail {
    display: none;
}

.ant-slider-track {
    position: relative;
    height: 25px;
    opacity: .4;
}

.ant-slider-handle {
    top: 7px;
}

效果图

相关推荐
江城开朗的豌豆4 分钟前
拆解Redux:从零手写一个状态管理器,彻底搞懂它的魔法!
前端·javascript·react.js
鸢栀w6 分钟前
前端css学习笔记7:各种居中布局&空白问题
前端·css·笔记·学习·尚硅谷网课
excel7 分钟前
「前端必修」BOM 全面解析:从 window 到 history 的完整指南
前端
啃火龙果的兔子7 分钟前
onRequestHide at ORIGIN_CLIENT reason HIDE_SOFT_INPUT fromUser false
前端
中草药z9 分钟前
【自动化测试】Selenium详解-WebUI自动化测试
前端·功能测试·selenium·自动化·html·web·测试
知识分享小能手6 小时前
Vue3 学习教程,从入门到精通,Axios 在 Vue 3 中的使用指南(37)
前端·javascript·vue.js·学习·typescript·vue·vue3
程序员码歌8 小时前
【零代码AI编程实战】AI灯塔导航-总结篇
android·前端·后端
用户21411832636029 小时前
免费玩转 AI 编程!Claude Code Router + Qwen3-Code 实战教程
前端
小小愿望10 小时前
前端无法获取响应头(如 Content-Disposition)的原因与解决方案
前端·后端
小小愿望10 小时前
项目启功需要添加SKIP_PREFLIGHT_CHECK=true该怎么办?
前端