react 实现自定义拖拽hook

本文介绍了如何改进公司产品的拖拽功能,通过创建一个自定义React Hook来提供更好的用户体验。拖拽功能基于addEventListener监听鼠标事件,利用getBoundingClientRect()获取元素位置,并在鼠标移动时更新元素位置。详细代码及使用方法在正文中给出。
摘要由CSDN通过智能技术生成

前沿

最近发现公司的产品好几个模块用到了拖拽功能,之前拖拽组件是通过Html5 drag Api 实现的但体验并不是很好,顺便将原来的拖拽组建稍做修改,写一个自定义hook,方便大家使用拖拽功能。

正文

拖拽功能原理:

  1. 拖拽元素通过addEventListener监听器添加鼠标按下,鼠标移动,以及鼠标抬起事件。
  2. 再通过getBoundingClientRect() 得到拖拽元素四周相对于可拖拽区域边界的距离。
  3. 鼠标移动时计算x轴和y轴的移动偏移量。
  4. 通过element.style.transform 设置元素移动。
  5. 每次拖拽完成后,都将此次偏移量保存,下次再次拖拽时,可以保证位置的实时性。

代码开发:

useDrag.jsx

import {
    useEffect, useState } from "react";
/*
 * @drag: 添加拖拽事件的元素(支持传入元素的drager,id,class等)必填参数
 * @draggerBox: 被拖拽的整体元素(支持传入元素的dragger,id,class等)可选参数
 * @container: 可拖拽的区域(支持传入元素的dragger,id,class等)可选参数
 * @maring: 离外部元素的间隔 可选参数
 */
export default function useDrag({
    dragger, draggerBox = dragger, container = document.body, maring = [0, 0, 0, 0] }) {
   
  const [translateX, setTranslateX] = useState(0); // 水平方向偏移量
  const [translateY, setTranslateY] = useState(0); // 垂直方向偏移量

  useEffect(() => {
   
    if (!dragger) return;
    if (!draggerBox) return;
    if (!container) return;
    dragger = 
  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值