react dnd的用法是什么

react dnd用于构建复杂的拖放界面,并保持组件之间的耦合,是一组react高阶组件;使用时只需用对应的API将目标组件包裹,即可实现拖动或接受拖动元素的功能;不需要判断拖动状态,只需在传入的spec对象中各个状态属性中做对应处理即可。

react dnd的用法是什么

本教程操作环境:Windows10系统、react17.0.1版、Dell G3电脑。

react dnd的用法是什么

React-DnD是一组React实用程序,可帮助您构建复杂的拖放界面,同时保持组件之间的耦合。它非常适合Trello和Storify之类的应用程序,其中拖动可在应用程序的不同部分之间传输数据,并且组件可以响应拖放事件更改其外观和应用程序状态。

如上图的团队任务合作平台很多公司都在使用。React-DnD是这一类业务场景的优秀开源解决方案。

接下来我们先介绍一下它的使用方法。

使用方法

安装

02.png

安装的时候我们需要同时安装backend与react-dnd。

为什么与要这样设计呢,后面源码解析的时候会详细说明。

DndProvider注入

DndProvider组件为您的应用程序提供React-DnD功能。必须通过backendc参数将其注入后端,但是也可以将其注入window对象。

backend后端是React-DnD中非常好的一种设计方法。可以理解为具体拖拽的实现方式。

03.png

DndProvider api

backend: 必填,dnd后端可以使用官方的提供的两个 HTML5Backend or TouchBackend,或者也可以自己写backend后端。

context: 选填,用户配置后端的上下文,这取决于后端的实现。

options: 配置后端对象,自定义时可以传入backend。后面有例子。

useDrag 声明拖动源

userDrag用于将当前组件用作拖动源的钩子。

04.png

其中useDrag返回的参数有

arguments[0]: 一个对象,其中包含从collect函数收集的属性。如果collect未定义函数,则返回一个空对象。

arguments[1]: 拖动源的连接器功能。这必须附加到DOM的可拖动部分。

arguments[2]: 用于拖动预览的连接器功能。这可以附加到DOM的预览部分。

然后useDrag传入的参数有

item: 必填。一个普通的JavaScript对象,描述了要拖动的数据。这是可用于放置目标的有关拖动源的唯一信息

item.type: 必填,并且必须是字符串,ES6符号。只有注册为相同类型的放置目标才会对此项目做出反应

previewOptions: 选填。描述拖动预览选项的普通JavaScript对象

options: 选填,一个普通的对象。如果组件的某些道具不是标量的(即不是原始值或函数),则arePropsEqual(props, otherProps)在options对象内部指定自定义函数可以提高性能。除非您有性能问题,否则不要担心。

begin(monitor):选填,拖动操作开始时触发。不需要返回任何内容,但是如果返回对象,它将覆盖item规范的默认属性。

end(item, monitor):选填,拖动停止的时候,end将会被调用。

canDrag(monitor):选填。使用它可以指定当前是否允许拖动。默认允许

isDragging(monitor):选填。默认情况下,只有启动拖动操作的拖动源才被视为拖动

collect:选填,收集功能。

推荐学习:《react视频教程》

以上就是react dnd的用法是什么的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2933520.html

(0)
上一篇 2025年3月11日 20:32:24
下一篇 2025年2月19日 00:51:41

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • react withrouter的用法是什么

    react withrouter用于将一个组件包裹进Route里面,并将“react-router”的三个history、location、match对象传入props对象,引入语法为“import{withRouter}from&#823…

    2025年3月11日
    200
  • 什么时候使用react-redux

    使用“react-redux”的场景:1、用户的使用方式复杂时;2、不同身份的用户有不同的使用方式时;3、多个用户之间可以协作时;4、与服务器大量交互,或者使用了WebSocketView时;5、要从多个来源获取数据时。 本教程操作环境:W…

    2025年3月11日
    200
  • react跟vue的diff算法有什么区别

    区别:1、当节点元素类型相同,但className不同时,vue认为是不同类型元素,会删除重建,而react会认为是同类型节点,只修改节点属性;2、列表比对,vue采用从两端到中间的比对方式,而react则采用从左到右依次比对的方式。 本教…

    2025年3月11日
    200
  • 什么是React Fiber

    React Fiber是一个类似双向链表的数据结构;ReactDom会根据jsx,为每个dom节点生成一个fiber节点,child指向第一个子节点、sibling指向下一个兄弟节点、return指向父节点的数据结构就是fiber数据结构。…

    2025年3月11日
    200
  • react的ssr项目是什么

    在react中,ssr是“Server Side Rendering”的缩写,是服务器端渲染的意思;ssr是将同一个组件渲染为服务器端的HTML字符串并发送到浏览器,将这些静态标记”激活”为客户端上完全可交互的应用程…

    2025年3月11日
    200
  • react中forceupdate的用法是什么

    在react中,forceupdate()用于强制使组件跳过shouldComponentUpdate(),直接调用render(),可以触发组件的正常生命周期方法,语法为“component.forceUpdate(callback)”。…

    2025年3月11日
    200
  • react是不是mvvm框架

    react不是mvvm框架。mvvm框架需要有一个vm对象来映射view,也即vm对象的属性发生改变的时候,对应的视图部分会相对应更新;而react中并没有vm对象,有的是属性和状态,整体可作为View使用,所以react不是mvvm框架。…

    2025年3月11日
    200
  • react中hooks解决了什么问题

    解决的问题:1、从组件中提取状态逻辑,解决了在组件之间复用状态逻辑很难的问题;2、将组件中相互关联的部分拆分成更小的函数,解决了复杂组件的问题;3、在非class的情况下使用更多的React特性,解决了class组件与函数组件有差异的问题。…

    2025年3月11日
    200
  • node和react有什么区别

    node和react的区别是:nodejs是一个基于Chrome JavaScript运行时建立的一个平台,可用于方便地搭建响应速度快、易于扩展的网络应用;而react是一个用于构建用户界面的JavaScript库,主要用于构建UI。 本教…

    2025年3月11日
    200
  • react的脚手架是什么意思

    在react中,脚手架是快速生成项目工程化结构工具的意思;React脚手架能够快速开始一个React的项目,生成一个通用的目录结构,并配置所需环境,其中包含基础的依赖库,只需要利用“npm install”就能够安装,节省了项目的配置时间。…

    2025年3月11日
    200

发表回复

登录后才能评论