返回顶部
首页 > 资讯 > 前端开发 > JavaScript >react-dnd实现任意拖动与互换位置
  • 386
分享到

react-dnd实现任意拖动与互换位置

2024-04-02 19:04:59 386人浏览 独家记忆
摘要

本文实例为大家分享了React-dnd实现任意拖动与互换位置的具体代码,供大家参考,具体内容如下 react-dnd用法 hooks组件 1.使用DndProvider定义一个可以拖

本文实例为大家分享了React-dnd实现任意拖动与互换位置的具体代码,供大家参考,具体内容如下

react-dnd用法

hooks组件

1.使用DndProvider定义一个可以拖拽的范围

import { HTML5Backend } from 'react-dnd-html5-backend';
import { DndProvider } from 'react-dnd';

class App extends Component{
  render () {
    return (
      <div>
        <DndProvider backend={HTML5Backend}>
          <Container />
        </DndProvider>
      </div>
    )
  }
}

2.定义drag和drop

drag:就是可以被拖拽的东西

drop: 就是拖拽后可以放的地方

import { useDrag } from 'react-dnd';




const Drag = ({ name }) => {
  const [{isDragging}, drag] = useDrag({
    type: 'test',
    end(item, monitor) {   
        monitor.getDropResult()   //获取拖拽对象所处容器的数据
        monitor.didDrop()    // 当前容器能否放置拖拽对象
    }    
  })

  return (
    <div id="drag">{name}</div>
  )
}
import { useDrop } from 'react-dnd';



const Container = (props) => {
  const [{isOver, canDrop}, drop] = useDrop({
    accept: 'test',
    drop: (item, monitor) => ({ 
        dropname: '测试', 
        top: monitor.getDifferenceFromInitialOffset().y,
        left: monitor.getDifferenceFromInitialOffset().x 
     }),  
    // 可以在这里配置数据,与drag中monitor.getDropResult()获取的信息关联
    collect: (monitor) => ({
      isOver: monitor.isOver(),   // 返回拖拽对象是否悬浮在该容器上
      canDrop: monitor.canDrop(),  // 当前容器是否支持拖拽对象放置
    })
  })

  return (
    <div ref={drop}>
        ...
    </div>
  )
}

实现任意拖拽

1.在容器中通过drop —> monitor.getDifferenceFromInitialOffset()获取拖拽对象当前位置与初始位置的偏移量

2.在drag的end中,通过monitor.getDropResult()获取到与初始位置的偏移量,给当前拖拽元素的偏移量重新赋值,即可做到任意拖拽

3.如果同时有很多个可拖拽的对象,需要给他们定义一个index值, 因为这个可拖拽组件是复用的,所以我们获取到的拖拽对象是个数组,我们可以用index作为下标,给当前拖拽组件单独赋值

const Drag = ({ name, top, left, index }) => {
  const [{isDragging}, drag] = useDrag({
    type: 'test',
    end(item, monitor) {
      console.log(item);
      if(monitor.didDrop()){
        const droptarget = monitor.getDropResult();
        const top = document.querySelectorAll('#drag')[index].offsetTop;
        const left = document.querySelectorAll('#drag')[index].offsetLeft;
        document.querySelectorAll('#drag')[index].style.top = (top + droptarget.top) + 'px';
        document.querySelectorAll('#drag')[index].style.left = (left + droptarget.left) + 'px';
      }else{
        console.log(monitor.getDropResult());
      }
    }
  })

  return (
    <div id="drag" index={index} ref={drag} style={{position: 'absolute', top: `${top}`, left: `${left}`, width: '70px', height: '40px', border: '1px solid black'}}>{name}</div>
  )
}
const Container = (props) => {
  const [{isOver, canDrop}, drop] = useDrop({
    accept: 'test',
    drop: (item, monitor) => ({ dropname: '测试', top: monitor.getDifferenceFromInitialOffset().y, left: monitor.getDifferenceFromInitialOffset().x }),
    collect: (monitor) => ({
      isOver: monitor.isOver(),
      canDrop: monitor.canDrop(),
    })
  })

  return (
    <div
      id="drop1"
      ref={drop}
      style={{width: '700px', height: '600px', backgroundColor: 'yellow'}}
    >

    </div>
  )
}

拖拽互换位置

拖拽互换位置需要组件既是drag拖拽对象,也是drop拖拽容器。所以使用useRef()定义ref,然后 drag(drop(ref)),让它即作为拖拽对象也作为拖拽容器,然后定义拖拽结束事件

import React, { useRef, useMemo } from 'react';
import { useDrag, useDrop } from 'react-dnd';
import { item } from './itemType';

const style = {
  display: 'inline',
  border: '1px dashed gray',
  padding: '0.5rem 1rem',
  marginRight: '30px',
  marginTop: '.5rem',
  backgroundColor: 'blue',
  cursor: 'move',
  borderRadius: '50%',
  position: 'relative',
};

const Drag = (props) => {
  const ref = useRef()

  const [{}, drop] = useDrop({
    accept: item.type,
    drop: (item, monitor) => {
        return {
          index: props.index
        }
    }
  })

  const count = useMemo(() => {
    document.getElementById('delete').oncontextmenu = (e) => {
      e.preventDefault();
    }
  },[1])

  const [{}, drag] = useDrag({
    type: item.type,
    end: (item, monitor) => {
      console.log(monitor.didDrop());
      if(monitor.didDrop()){
        const dropResult = monitor.getDropResult();
        props.changePosition([props.index, dropResult.index])
      }else{
        return;
      }
    }
  })

  drag(drop(ref))

  return (
    <div id="delete" ref={ref} id="drag" index={props.index} style={{...style}} >
      <span>{props.name}</span>
      <span style={{position: 'absolute', border: '1px solid gray', top: "18.5px", left: '145px', width: '29px',background: 'gray'}}></span>
    </div>
  )
}

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

--结束END--

本文标题: react-dnd实现任意拖动与互换位置

本文链接: https://lsjlt.com/news/166125.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • react-dnd实现任意拖动与互换位置
    本文实例为大家分享了react-dnd实现任意拖动与互换位置的具体代码,供大家参考,具体内容如下 react-dnd用法 hooks组件 1.使用DndProvider定义一个可以拖...
    99+
    2024-04-02
  • Android实现view拖动到任意位置
    本文实现:将图片任意拖动,如果拖动到正确位置则成功,若抬起手时时错误位置则自动回到原位。 定义 private ImageView img; private ImageView ...
    99+
    2024-04-02
  • Android实现view拖动到任意位置的方法
    小编给大家分享一下Android实现view拖动到任意位置的方法,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!本文实现:将图片任意拖动,如果拖动到正确位置则成功,...
    99+
    2023-06-14
  • javascript拖曳互换div的位置实现示例
    1 实现原理 利用dom元素的dragstart/ondragover/ondrop事件完成,在拖曳开始的时候获取到拖曳元素,然后允许拖动,最后鼠标抬起后放到新的位置;这里用到了ev...
    99+
    2024-04-02
  • Vue实现DOM元素拖放互换位置示例
    目录一、拖放和释放二、可拖拽属性三、DataTransfer3.1 属性3.2 方法四、DataTransferItem4.1 属性4.2 方法五、DataTransferItemL...
    99+
    2023-01-28
    Vue DOM拖放互换 Vue DOM拖放
  • Flutter 实现任意控件拖动
    文章目录 前言一、如何实现?1、使用GestureDetector响应拖动事件2、使用Transform变换控件位置3、计算拖动区域 二、完整代码三、使用示例1、基本用法 总结 ...
    99+
    2023-09-10
    flutter 前端 dart windows android
  • vue实现拖拽交换位置
    本文实例为大家分享了vue实现拖拽交换位置的具体代码,供大家参考,具体内容如下 <template>   <div class="root">     <...
    99+
    2024-04-02
  • vue怎么实现拖拽交换位置
    这篇文章主要介绍“vue怎么实现拖拽交换位置”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“vue怎么实现拖拽交换位置”文章能帮助大家解决问题。具体代码如下<template> ...
    99+
    2023-06-29
  • 组织结构是否可以任意拖动到指定位置div
    今天就跟大家聊聊有关组织结构是否可以任意拖动到指定位置div,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。 首先用js...
    99+
    2024-04-02
  • Android的RecyclerView实现列表拖动(移动顺序)交换数据位置
    先看效果图 这是拖动前的图片 这是拖动列表改变位置后的图片 这里放上视频演示 RecyclerView实现列表拖动交换数据位置 主活动MainActivity2类代码如下 import androidx.appcompat...
    99+
    2023-08-30
    android java 开发语言
  • JS实现元素的拖动与占位功能
    这篇博客,是博主这几天刚做的一个项目遇到的一个难点,学会了这个,你就能轻松实现页面元素的移动啦,再配合一些条件,就可以做出一个任务完成进度的页面了! 先来看看效果:  ...
    99+
    2024-04-02
  • SpringBoot实现任意位置获取HttpServletRequest对象
    目录任意位置获取HttpServletRequest对象方法一方法二HttpServletRequest只能读取一次的解决任意位置获取HttpServletRequest对象 方法一...
    99+
    2024-04-02
  • Android如何使用RecycleView实现拖拽交换item位置
    小编这次要给大家分享的是Android如何使用RecycleView实现拖拽交换item位置,文章内容丰富,感兴趣的小伙伴可以来了解一下,希望大家阅读完这篇文章之后能够有所收获。老规矩,先来一张效果图:相比起ListView而言,Recyc...
    99+
    2023-05-30
    recycleview android recycle
  • JS如何实现元素的拖动与占位功能
    这篇文章主要为大家展示了“JS如何实现元素的拖动与占位功能”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JS如何实现元素的拖动与占位功能”这篇文章吧。先来看看效果:  实现功...
    99+
    2023-06-25
  • jQuery实现鼠标拖动div改变位置、大小的实践
           实现类似windows窗体的效果,在中间拖动改变div位置,在边缘拖动改变div大小,鼠标在相应的...
    99+
    2024-04-02
  • jQuery实现鼠标拖动div改变位置、大小的操作
    本篇内容主要讲解“jQuery实现鼠标拖动div改变位置、大小的操作”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“jQuery实现鼠标拖动div改变位置、大小的操作”吧!  ...
    99+
    2023-06-14
  • Android ScrollView显示到底部或任意位置实现代码
     Android ScrollView显示到底部或任意位置 其实使ScrollView显示底部并不难。它有自己的方法fullScroll():  &nbs...
    99+
    2022-06-06
    scrollview Android
  • 如何使用jQuery实现两个div中按钮互换位置
    这篇文章将为大家详细讲解有关如何使用jQuery实现两个div中按钮互换位置,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。效果如下 代码如下:<head&...
    99+
    2024-04-02
  • Android实现让图片在屏幕上任意移动的方法(拖拽功能)
    本文实例讲述了Android实现让图片在屏幕上任意移动的方法。分享给大家供大家参考,具体如下: public class DragExampleActivity extend...
    99+
    2022-06-06
    方法 图片 Android
  • MAUI模仿iOS多任务切换卡片滑动的交互实现代码
    目录原理平铺分布iOS多任务卡片分布创建布局创建分布函数创建动效创建绑定数据细节调整跳转到最后一张卡片上一篇博文的评论,大家对MAUI还是比较感兴趣的,非常感谢大家的关注,这个专栏我...
    99+
    2023-05-18
    ios多任务切换卡片滑动 ios卡片滑动切换
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作