欢迎光临

我们一直在努力
当前位置:首页 > 编程技术 >

react优雅处理多条件鼠标拖拽位移

日期:
后台-插件-广告管理-首页/栏目/内容广告位一(PC)
后台-插件-广告管理-首页/栏目/内容广告位一(手机)

本文实例为大家分享了react优雅处理多条件鼠标拖拽位移的具体代码,供大家参考,具体内容如下

场景

三种拖拽条件 可纵轴 横轴 和全部方向 如果加3个监听重复代码太多
因为状态更改组件会重新渲染 所以写的时候要多注意避免有大量代码的函数多次创建销毁

state

const [position, setPosition] = useState(axisPosition);

jsx

<Container
  >phpt;
  </Container>

监听

const handleDown =
 (position: IPosition, setState: (position: IPosition) => void) => (e: React.MouseEvent<htmlElement, MouseEvent>) => {
  const startX = e.pageX;
  const startY = e.pageY;
  const { top, left } = position;
  const move = (ev: MouseEvent) => {
   const disX = ev.pageX - startX;
   const disY = ev.pageY - startY;
   setState({ left: left + disX, top: top + disY });
  };

  const cancel = () => {
   document.removeEventListener("mousemove", move);
   document.removeEventListener("mouseup", cancel);
   document.removeEventListener("mouseleave", cancel);
  };

  document.addEventListener("mousemove", move);
  document.addEventListener("mouseup", cancel);
  document.addEventListener("mouseleave", cancel);
 };

业务代码

/*
* @Author: hongbin
* @Date: 2022-04-03 13:38:02
* @LastEditors: hongbin
* @LastEditTime: 2022-04-03 21:49:42
* @Description:移动坐标轴
*/
import { FC, ReactElement, useEffect, useState } from "react";
import styled from "styled-components";
import { useElementContext } from "../../context/ElementContext";
import { FlexCenter } from "../../styled";

interface IProps {}

interface IPosition {
 top: number;
 left: number;
}

const handleDown =
 (position: IPosition, setState: (position: IPosition) => void) => (e: React.MouseEvent<HTMLElement, MouseEvent>) => {
  const startX = e.pageX;
  const startY = e.pageY;
  const { top, left } = position;
  const move = (ev: MouseEvent) => {
   const disX = ev.pageX - startX;
   const disY = ev.pageY - startY;
   setState({ left: left + disX, top: top + disY });
  };

  const cancel = () => {
   document.removeEventListener("mousemove", move);
   document.removeEventListener("mouseup", cancel);
   document.removeEventListener("mouseleave", cancel);
  };

  document.addEventListener("mousemove", move);
  document.addEventListener("mouseup", canphpcel);
  document.addEventListener("mouseleave", cancel);
 };

const Axis: FC<IProps> = (): ReactElement => {
 const {python axisPosition } = useElementContext();
 const [position, setPosition] = useState<IPosition>(axisPosition);

 useEffect(() => {
  setPosition(axisPosition);
 }, [axisPosition]);

 return (
  <Container
  >php  border-right-color: transparent;
     transform-origin: top;
    }
   }
   :last-child {
    cursor: ew-resize;
    width: 3vw;
    height: 2px;
    background-color: blue;
    transform: translateX(60%);
    ::before {
     content: "";
     border: 4px solid blue;
     top: -3px;
     right: 0;
     position: absolute;
     transform: scaleX(4) rotate(-90deg) translateY(50%);
     border-left-color: transparent;
     border-right-color: transparent;
     border-bottom-color: transparent;
    }
   }
  }
  div {
   cursor: move;
   width: inherit;
   height: inherit;
   border: inherit;
   border-radius: inherit;
   background-color: inherit;
   position: absolute;
   z-index: 1;
  }
 }
`;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

后台-插件-广告管理-首页/栏目/内容广告位二(PC)
后台-插件-广告管理-首页/栏目/内容广告位二(手机)
后台-插件-广告管理-内容广告位三(PC)
后台-插件-广告管理-内容广告位三(手机)

相关阅读

后台-插件-广告管理-内容广告位四(PC)
后台-插件-广告管理-内容广告位四(手机)

热门文章

后台-插件-广告管理-侧边广告位一(PC)
后台-插件-广告管理-侧边广告位一(手机)
  • HTML 表单组件实例代码

  • HTML 表单用于搜集不同类型的用户输入。下文通过代码给大家分享html 表单组件实例代码,感兴趣的朋友参考下吧 废话不多说了,直接给大家贴代码了,具体代码如下所示: <!DOCTYPE
  • html2canvas 将html代码转为图片的使用方法

  • 转换代码到图片使用 html2canvas,这是一个非常著名的从浏览器网页截图的开源库,使用很方便,功能也很强大。 使用 html2canvas http:// html2canvas 的使用非常简单,简单
  • HTML网页中插入视频的方法小结

  • 现在如果要在页面中使用video标签,需要考虑三种情况,支持Ogg Theora或者VP8(如果这玩意儿没出事的话)的(Opera、Mozilla、Chrome),支持H.264的(Safari、IE 9、Chrome),都不支持的(IE6、
  • HTML实现文本框只读不能修改其中的内容

  • 废话不多说了,直接给大家贴代码了,具体代码如下所示: <!--方法1:>http:// 当鼠标放不上就离开焦点 --> <input type="text" name="input1" value=http://www.cppcns.com/web
  • 移动端专用的meta标签设置大全

  • 前言 之前学习前端中,对meta标签的了解仅仅只是这一句。 <meta charset="UTF-8"> 但是打开任意的网站,其head标签内都有一列的meta标签。比如我们我们网站,但是自己却很不熟
后台-插件-广告管理-侧边广告位二(PC)
后台-插件-广告管理-侧边广告位二(手机)

最新文章

  • 在Asp.net core项目中使用WebSocket

  • 今天小试了一下在ASP.NET core中使用websocket,这里记录一下: 在 Startup 类的 Configure 方法中添加 WebSocket 中间件。 app.UseWebSockets(); 它也可以传入一些参数 app.Us
  • Vue快速理解事件绑定是什么

  • 目录一、监听事件二、事件修饰符1、stop修饰符阻止事件冒泡2、capture修饰符3、self修饰符4、prevent修饰符5、键盘事件修饰符6、鼠标事件修饰符一、监听事件 监听事件一般
  • C#实现模拟ATM自动取款机功能

  • 目录(1)关于用户帐号的类:Account(2)关于银行数据库的类:BankDatabase(3)关于ATM屏幕显示的类:Screen(4)关于ATM键盘的类:Keypad(5)关于进钞、出钞口的类:DepositSlot(6)关于ATM
  • Java设计模式之抽象工厂模式浅析讲解

  • 1.介绍 当系统准备为用户提供一系列相关对象,又不想让用户代码和这些对象形成耦合时,就可以使用抽象工厂模式。 2.如何实现 1)抽象产品--Car 2)具体产品--BYDCar、TSLCar 3)抽象
  • 如何动态替换Spring容器中的Bean

  • 目录动态替换Spring容器中的Bean原因方案实现Spring中的bean替换问题动态替换Spring容器中的Bean 原因 最近在编写单测时,发现使用 Mock 工具预定义 Service 中方法的行为特
  • C#优雅的实现INotifyPropertyChanged接口

  • INotifyPropertyChanged接口在wpF或WinFrom程序中使用还是经常用到,常用于通知界面属性变更。标准写法如下: class NotifandroidyObject : INotifyPropertyChanged {
后台-插件-广告管理-侧边广告位三(PC)
后台-插件-广告管理-侧边广告位三(手机)