react拖拽react-beautiful-dnd,一维数组,二维数组

写在前边,二维数组可以拖拽,但是不可以编辑+拖拽,如果想要实现编辑+拖拽,还是需要转换成一维数组。原因是因为插件的官方规定,在拖拽过程中不可以编辑Droppable层的Props。

 

相关地址:

中文文档地址

react-beautiful-dnd - 《react-beautiful-dnd 中文文档帮助手册教程》 - 极客文档 (geekdaxue.co)

git源码

GitHub - chinanf-boy/react-beautiful-dnd-zh: 🇨🇳翻译: react-beautiful-dnd 文档 ❤️ 更新 ✅

使用

安装

# yarn
yarn add react-beautiful-dnd

# npm
npm install react-beautiful-dnd --save

引入

import { DragDropContext, Droppable, Draggable } from 'react-beautiful-dnd';

引用

<DraggableList data={listDemo}></DraggableList>

一维数组使用

传参data是一维数组

import React, { useEffect, useState } from 'react';
import { DragDropContext, Draggable, Droppable } from 'react-beautiful-dnd';interface Props {data: any[];
}
const DraggableList: React.FC<Props> = ({ data }) => {const [sortList, setSortList] = useState([]);const getItems = () => {const arr = Array.from({ length: 10 }, (v, k) => k).map((k) => ({id: `item-${k}`,content: `item ${k}`,}));setSortList(arr);};useEffect(() => {getItems();}, []);const grid = 8;const getItemStyle = (isDragging, draggableStyle) => ({// some basic styles to make the items look a bit niceruserSelect: 'none',padding: grid * 2,margin: `0 ${grid}px 0 0`,// change background colour if draggingbackground: isDragging ? 'lightgreen' : 'grey',// styles we need to apply on draggables...draggableStyle,});const getListStyle = (isDraggingOver: any) => ({background: isDraggingOver ? 'lightblue' : 'lightgrey',display: 'flex',padding: grid,overflow: 'auto',});const onDragEnd = (result) => {if (!result.destination) {return;}console.log('end', sortList, result);const res = sortList.filter((item) => item); // 更改引用地址console.log('移动前res', res);const [removed] = res.splice(result.source.index, 1);console.log('删除???', removed);res.splice(result.destination.index, 0, removed);console.log('添加后', res);setSortList(res);};console.log('data', data);/*** Draggable组件可以拖动并拖放到其Droppables上. 一个Draggable必须始终包含在一个Droppable.* 它是 可能重新排序Draggable在其Droppable家中或移动到另一个Droppable.* 一个Draggable必须包含在一个Droppable.* */return (<DragDropContext onDragEnd={onDragEnd}><Droppable droppableId="droppable" direction="horizontal">{(provided, snapshot) => (<div ref={provided.innerRef} style={getListStyle(snapshot.isDraggingOver)} {...provided.droppableProps}>{sortList.map((item, index) => (<Draggable key={item.id} draggableId={item.id} index={index}>{(provided, snapshot) => (<divref={provided.innerRef}{...provided.draggableProps}{...provided.dragHandleProps}style={getItemStyle(snapshot.isDragging, provided.draggableProps.style)}>{item.content}</div>)}</Draggable>))}{provided.placeholder}</div>)}</Droppable></DragDropContext>);
};
export default DraggableList;

二维数组的使用

import React, { useEffect, useState } from 'react';
import { DragDropContext, Draggable, Droppable } from 'react-beautiful-dnd';interface Props {data: any[];
}
const DraggableList: React.FC<Props> = ({ data = [] }) => {const [sortList, setSortList] = useState(data);const grid = 8;const getItemStyle = (isDragging, draggableStyle) => ({// some basic styles to make the items look a bit niceruserSelect: 'none',padding: grid * 2,margin: `0 ${grid}px 0 0`,// change background colour if draggingbackground: isDragging ? 'lightgreen' : 'grey',// styles we need to apply on draggables...draggableStyle,});const getListStyle = (isDraggingOver) => ({background: isDraggingOver ? 'lightblue' : 'lightgrey',display: 'flex',padding: grid,overflow: 'auto',});const onDragEnd = (result) => {if (!result.destination) {return;}console.log('end', sortList, result);const res = sortList.filter((item) => item); //修改引用地址console.log('res', res);const [removed] = res.splice(result.source.index, 1);console.log('删除???', removed);res.splice(result.destination.index, 0, removed);console.log('添加后', res);setSortList(res);};useEffect(() => {setSortList(data);}, [data]);console.log('data', data);return (<DragDropContext onDragEnd={onDragEnd}>{sortList.map((item, index) => {return (<Droppable droppableId={'droppable' + index} key={index} direction="vertical">{(provided, snapshot) => (<div ref={provided.innerRef} style={getListStyle(snapshot.isDraggingOver)} {...provided.droppableProps}>{/*{data.map((item, index) => (*/}<Draggable key={item[0].value} draggableId={item[0].value} index={index}>{(provided, snapshot) => (<divref={provided.innerRef}{...provided.draggableProps}{...provided.dragHandleProps}style={getItemStyle(snapshot.isDragging, provided.draggableProps.style)}>{66666 + item[0].label}</div>)}</Draggable>{/*))}*/}{provided.placeholder}</div>)}</Droppable>);})}</DragDropContext>);
};
export default DraggableList;

组件传值的数组内容 

  const [options, setOptions] = useState([{label: '延时时间',value: 'delayTime',children: [{label: '时',value: 'hour',disabled: false,},{label: '分',value: 'minute',disabled: false,},{label: '秒',value: 'second',disabled: false,},],},{label: '限制类型',value: 'limitType',children: [{label: '前置点位1',value: '1',disabled: false,},{label: '前置点位2',value: '2',disabled: false,},{label: '前置点位3',value: '3',disabled: false,},],},{label: '温度',value: 'templete',},]);

案列

案例是通过级联的组件选择条件,新增条件时,前端重新定义数据格式,将二维的结构改成一维数组的结构。遍历填充内容时,是在Droppable的下一级,所以可以修改内容。

  const onDispatchValue = (res: any) => {dispatch({type: `${MODEL_NAME}/save`,payload: {proTypeList: res,},});}; // 新增、删除前置条件const [inputFlag, setInputFlag] = useState(false);const [listDemo, setListDemo] = useState([]);const changeCondition = (ids, option) => {let arr2 = [];// 第三层关系选中两个时的判断if (ids && ids.length > 1) {// 二维数组结构成一维数组,方便去重arr2 = ids.reduce((a, b) => {return a.concat(b);});const arr3 = Array.from(new Set(arr2));if (arr2.length !== arr3.length) {setRepeatFlag(true);return message.warning('前置条件重复,请删除!');} else {setRepeatFlag(false);}}// 没有子级或者全选的判断ids.map((item, index) => {if (item.length === 1 && option[index][0].value === item[0] && option[index][0]?.children?.length > 0) {setRepeatFlag(true);return message.warning('前置条件重复,请删除!');} else {setRepeatFlag(false);}});const arr = option.map((item) => {let obj = {typeName: '', // 类型名称typeValue: '', // 类型idunitName: '', // 单位名称unitValue: '', // 单位idvalue: '', // 值};item.map((i, index) => {if (item.length === 1) {obj.typeName = i.label;obj.typeValue = i.value;}if (item.length === 2) {if (index === 1) {obj.unitName = i.label;obj.unitValue = i.value;} else {obj.typeName = i.label;obj.typeValue = i.value;}}});return obj;});setListDemo(arr);// 保存定义好的数据,用于组件之间传值onDispatchValue(arr);};
// 父组件引用
<DraggableList data={proTypeList}></DraggableList>
// 子组件
import { ConnectState } from '@/typing/connect';
import { connect } from '@@/exports';
import { Input } from 'antd';
import React, { useEffect, useState } from 'react';
import { DragDropContext, Draggable, Droppable } from 'react-beautiful-dnd';
import { Dispatch } from 'umi';
interface Props {data: any[];dispatch: Dispatch;
}const MODEL_NAME = 'mainConfig';
const DraggableList: React.FC<Props> = ({ data = [], dispatch }) => {const [sortList, setSortList] = useState(data);// 拖拽时的样式const getListStyle = () => ({overflow: 'auto',width: '100%',});// 拖拽后的样式const getItemStyle = (isDragging, draggableStyle) => ({// some basic styles to make the items look a bit nicerwidth: '100%',userSelect: 'none',...draggableStyle,});const onDragEnd = (result) => {if (!result.destination) {return;}const res = sortList.filter((item) => item); //修改引用地址const [removed] = res.splice(result.source.index, 1);res.splice(result.destination.index, 0, removed);// console.log('添加后', res);setSortList(res);dispatch({type: `${MODEL_NAME}/save`,payload: {proTypeList: res,},});console.log('拖拽后', res);};// 校验输入框内容const regInputValue = (e: any, index: number) => {// 输入框聚焦时const arr = data.filter((item) => item);arr[index].value = e.target.value;console.log('arr', arr);setSortList(arr);dispatch({type: `${MODEL_NAME}/save`,payload: {proTypeList: arr,},});};useEffect(() => {setSortList(data);}, [data]);// console.log('弹窗起落data', data);/*** Draggable组件可以拖动并拖放到其Droppables上. 一个Draggable必须始终包含在一个Droppable.* 它是 可能重新排序Draggable在其Droppable家中或移动到另一个Droppable.* 一个Draggable必须包含在一个Droppable.* */return (<DragDropContext onDragEnd={onDragEnd}><Droppable droppableId="droppable" direction="horizontal">{(provided, snapshot) => (<div ref={provided.innerRef} style={getListStyle(snapshot.isDraggingOver)} {...provided.droppableProps}>{data.map((item, index) => (<Draggable key={item.typeValue} draggableId={item.typeValue} index={index}>{(provided, snapshot) => (<divref={provided.innerRef}{...provided.draggableProps}{...provided.dragHandleProps}style={getItemStyle(snapshot.isDragging, provided.draggableProps.style)}><div style={{ width: '100%', display: 'flex', justifyContent: 'flex-start', textAlign: 'center' }}><div style={{ width: '33%', backgroundColor: '#f2f2f2', padding: '8px 0' }}>条件名称</div><div style={{ width: '33%', backgroundColor: '#f2f2f2', padding: '8px 0' }}>条件值</div><div style={{ width: '33%', backgroundColor: '#f2f2f2', padding: '8px 0' }}>单位名称</div></div><divstyle={{width: '100%',display: 'flex',justifyContent: 'flex-start',padding: '6px',textAlign: 'center',marginBottom: 16,}}><div style={{ width: '33%', padding: '8px 0' }}>{item.typeName}</div><div style={{ width: '33%', padding: '8px 0' }}><Inputplaceholder="请输入内容"onChange={(e) => {regInputValue(e, index);}}/></div><div style={{ width: '33%', padding: '8px 0' }}>{item.unitName}</div></div></div>)}</Draggable>))}{provided.placeholder}</div>)}</Droppable></DragDropContext>);
};
export default connect(({ mainConfig }: ConnectState) => ({mainConfig ,
}))(DraggableList);

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/762001.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

VUE中添加视频播放功能

转载https://www.cnblogs.com/gg-qq/p/10782848.html 常见错误 vue-video-player下载后‘vue-video-player/src/custom-theme.css‘找不到 解决方法 卸载原来的video-play版本 降低原来的版本 方法一 npm install vue-video-player5.0.1 --save 方法二 或者是在pack.json中直…

OpenGL学习笔记【4】——创建窗口

一、前三章节的前情回顾 章节一&#xff1a;上下文(Context) OpenGL学习笔记【1】——简介-CSDN博客 章节一讲述了OpenGL在渲染的时候需要一个Context来记录了OpenGL渲染需要的所有信息和状态&#xff0c;可以把上下文理解成一个大的结构体&#xff0c;它里面记录了当前绘制使…

JVM垃圾回收之内存分配,死亡对象判断方法

Java 堆是垃圾收集器管理的主要区域&#xff0c;因此也被称作 GC 堆。 堆划分为新生代 老生代 永久代。 下图所示的 Eden 区、两个 Survivor 区 S0 和 S1 都属于新生代&#xff0c;中间一层属于老年代&#xff0c;最下面一层属于永久代。 内存分配原则 对象优先在Eden区域分…

基于PID控制器的四旋翼无人机控制系统的simulink建模与仿真,并输出虚拟现实动画

目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 4.1四旋翼无人机的动力学模型 4.2 PID控制器设计 4.3 姿态控制实现 4.4 VR虚拟现实动画展示 5.完整工程文件 1.课题概述 基于PID控制器的四旋翼无人机控制系统的simulink建模与仿真,并输出vr虚拟现实…

Chronicles 是什么数据库

可以理解的是 Chronicles 是 EPIC 公司根据 IRIS 进行魔改后的一个 DBMS。 简单的来说 Chronicles 就是一个数据库管理系统&#xff0c;但这个数据库管理系统不是我们常说的关系数据库的管理系统。 数据库结构 只要对数据库有所了解的都知道数据库通常就是 2 个部分&#xf…

10W字解析 SpringBoot技术内幕文档,实战+原理齐飞,spring事务实现原理面试

第3章&#xff0c;Spring Boot构造流程源码分析&#xff0c;Spring Boot的启动非常简单&#xff0c;只需执行一个简单的main方法即可&#xff0c;但在整个main方法中&#xff0c;Spring Boot都做了些什么呢&#xff1f;本章会为大家详细讲解Spring Boot启动过程中所涉及的源代码…

会声会影2023新版本特点以及会声会影2023序列号注册机keygen下载

会声会影简介 虽然现在已经是2024年了&#xff0c;但是大家对会声会影2024的热爱一直不减&#xff0c;很多人后台问我&#xff0c;有没有会声会影2023序列号和注册机&#xff0c;这不&#xff0c;今天这篇文章它来了。 会声会影2023新版特性 1.全新的进入/中场/退出标题动态功…

【Godot 4.2】常见几何图形、网格、刻度线点求取函数及原理总结

概述 本篇为ShapePoints静态函数库的补充和辅助文档。ShapePoints函数库是一个用于生成常见几何图形顶点数据&#xff08;PackedVector2Array&#xff09;的静态函数库。生成的数据可用于_draw和Line2D、Polygon2D等进行绘制和显示。因为不断地持续扩展&#xff0c;ShapePoint…

基于Springboot的在线投稿系统+数据库+免费远程调试

项目介绍: Javaee项目&#xff0c;springboot项目。采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系结构&#xff0c;通过Spring SpringBoot Mybatis VueMavenLayui来实现。MySQL数据库作为系统数据储存平台&a…

计算机组成原理 双端口存储器原理实验

一、实验目的 1、了解双端口静态随机存储器IDT7132的工作特性及使用方法 2、了解半导体存储器怎样存储和读出数据 3、了解双端口存储器怎样并行读写&#xff0c;产生冲突的情况如何 二、实验任务 (1)按图7所示&#xff0c;将有关控制信号和和二进制开关对应接好&#xff0c;…

工控机丨丨工业电脑丨工控计算机丨工业一体机丨什么是工业一体机

工业一体机俗称工控机&#xff0c;是一种专门为工业应用而设计的计算机设备&#xff0c;主要应用于工厂、车间、仓库等工业场所。此外工控机还叫做工控计算机&#xff0c;通常采用工业级主板、工业级CPU、工业级硬盘、工业级内存和工业级电源等硬件组件&#xff0c;以确保其在高…

解决angualr13 form表单设置disabled不起作用问题

我的博客原文&#xff1a;解决angualr13 form表单设置disabled不起作用问题 问题 我们在angular项目中form中disabled 属性和 formControlName 结合使用时&#xff0c;会发现disabled 属性不会起作用&#xff0c;代码如下 ​ 效果却是 ​ 这是为什么呢&#xff1f; 原…

LeetCode每日一题——数组串联

数组串联OJ链接&#xff1a;1929. 数组串联 - 力扣&#xff08;LeetCode&#xff09; 题目&#xff1a; 思路&#xff1a; 题目说 ans 由两个 nums 数组 串联 形成。那么我们就只需要历遍两次nums数组&#xff0c;将它放在我们的ans数组里。 注意&#xff1a; 题目函数对于我…

广州5k前端面试题惊呆我!!!(内容太肝,谨慎入内)

&#x1f31f; 前言 欢迎来到我的技术小宇宙&#xff01;&#x1f30c; 这里不仅是我记录技术点滴的后花园&#xff0c;也是我分享学习心得和项目经验的乐园。&#x1f4da; 无论你是技术小白还是资深大牛&#xff0c;这里总有一些内容能触动你的好奇心。&#x1f50d; &#x…

MIT的研究人员最近开发了一种名为“FeatUp”的新算法,这一突破性技术为计算机视觉领域带来了高分辨率的洞察力

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

IIS7/iis8/iis10安装II6兼容模块 以windows2022为例

因安全狗的提示 安全狗防护引|擎安装失败 可能原因是: IIS7及以上版本末安装1IS6兼容模块! .所以操作解决 如下. 在开始菜单中,找到服务器管理器.找到下图的IIS,右键添加角色和功能,找到web服务器的管理工具选项,iis6管理兼容性 打钩并安装. 如下图

【RPG Maker MV 仿新仙剑 战斗场景UI (六)】

RPG Maker MV 仿新仙剑 战斗场景UI 六 法术战斗窗口代码仿新仙剑效果 法术战斗窗口 这次来水点内容 由于之前已经做过了仿新仙剑的法术及物品窗口因此本次两篇内容&#xff0c;就来水点内容&#xff01;&#xff01;&#xff01; 由于帮助窗口之前已经做过&#xff0c;因此直接…

知识蒸馏——深度学习的简化之道 !!

文章目录 前言 1、什么是知识蒸馏 2、知识蒸馏的原理 3、知识蒸馏的架构 4、应用 结论 前言 在深度学习的世界里&#xff0c;大型神经网络因其出色的性能和准确性而备受青睐。然而&#xff0c;这些网络通常包含数百万甚至数十亿个参数&#xff0c;使得它们在资源受限的环境下&…

【ubuntu20.04+tensorflow-gpu1.14配置】

ubuntu20.04tensorflow-gpu1.14配置 目录0. 版本注意事项说明1. 个人目录下载后配置系统环境变量2. anaconda配置所有环境&#xff08;过程简便&#xff0c;但容易出现不兼容问题&#xff09;3. 验证tensorflow-gpu4. 一些细节 目录 总结出两种方法 个人目录 下载cuda和cudnn…

评论家:大型语言模型可以通过工具交互式批评进行自我修正(ICLR2024)

1、写作动机&#xff1a; 大语言模型有时会显示不一致性和问题行为&#xff0c;例如产生幻觉事实、生成有缺陷的代码或创建令人反感和有毒的内容。与这些模型不同&#xff0c;人类通常利用外部工具来交叉检查和改进他们的初始内容&#xff0c;比如使用搜索引擎进行事实检查&am…