站长家园(原代码之家)(www.adminjie.com)网站源码,微信源码,游戏源码,商业源码分享平台。
当前位置:网站首页 技术文章 网络编程 正文

react dnd的用法是什么

时间:2022-04-19 [网络编程]作者:fabuyuan 浏览:8 次

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

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

react dnd的用法是什么

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

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

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

使用方法

安装

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

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

DndProvider注入

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

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

DndProvider api

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

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

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

useDrag 声明拖动源

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

其中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的用法是什么的详细内容,更多请关注站长家园其它相关文章!

本文标签:  React

转载请注明来源:react dnd的用法是什么

本文永久链接地址:https://www.adminjie.com/post/11305.html

免责声明:
本站所发布的一切资源仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。

附:
二○○二年一月一日《计算机软件保护条例》第十七条规定:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬!鉴于此,也希望大家按此说明研究软件!

版权声明:
一、本站致力于为软件爱好者提供国内外软件开发技术和软件共享,着力为用户提供优资资源。
二、本站提供的部分源码下载文件为网络共享资源,请于下载后的24小时内删除。如需体验更多乐趣,还请支持正版。
三、我站提供用户下载的所有内容均转自互联网。如有内容侵犯您的版权或其他利益的,若有侵犯你的权益请:提交版权证明文件到邮箱 2225329873#qq.com(#换为@) 站长会进行审查之后,情况属实的会在三个工作日内为您删除。

  • 站长家园(原代码之家)会员升级
  • 最新文章
    • oracle怎么去掉前后的空格

      oracle怎么去掉前后的空格

      在oracle中,可用trim()函数来去掉前后的空格,当该函数的参数设置为both时,就会去除指定的首部和尾部字符,语法为“selecttrim(both...

    • oracle怎么查看表属于哪个用户

      oracle怎么查看表属于哪个用户

      方法:1、利用“SELECT*FROMDBA_TABLESWHERETABLE_NAME='表名'”语句查询;2、利用“...WHEREOBJECT...

    • css底部双描边是什么属性

      css底部双描边是什么属性

      css底部双描边是“border-bottom-style”属性,该属性用于设置元素底部边框的样式,当属性值设置为“double”时,可给元素的底部添加双实线边...

    • oracle怎么删除约束条件

      oracle怎么删除约束条件

      删除方法:1、利用“ALTERTABLE表名DROPUNIQUE(字段名);”语句删除表的单个字段约束;2、利用“ALTERTABLE表名DROP...

    • CSS里面能用odd吗

      CSS里面能用odd吗

      CSS里面能用odd。在CSS中,odd可以在伪类选择器中作为关键字选中指定元素,常作为“:nth-child()”选择器的参数,用于选取父元素中奇数行的指定子...

    热门文章