【dnd-kit】react前端做一个可以垂直拖动的无序列表 背景和效果需要做一个垂直拖动的无序列表。因项目中其他模块已经使用了dnd-kit, 为保持一致使用的也是dnd-kit。效果如下可拖拽列表示例资料React生态中主流拖拽库的深度对比与选型指南选型决策矩阵代码importReact,{useState}fromreact;import{DndContext,closestCenter,PointerSensor,useSensor}fromdnd-kit/core;import{SortableContext,verticalListSortingStrategy,useSortable}fromdnd-kit/sortable;import{CSS}fromdnd-kit/utilities;constmockData[{id:1,name:项目一},{id:2,name:项目二},{id:3,name:项目三},{id:4,name:项目四},{id:5,name:项目五},{id:6,name:项目六},]constDragableList(){const[items,setItems]useState(mockData);constsensoruseSensor(PointerSensor,{activationConstraint:{distance:5,},});// 可排序列表项组件constSortableItem({item}){const{attributes,listeners,setNodeRef,transform,transition,isDragging,}useSortable({id:item.id});conststyle{transform:CSS.Transform.toString(transform),// 决定拖拽效果transition,opacity:isDragging?0.5:1,cursor:grab,padding:12px,margin:8px 0,backgroundColor:#f8f9fa,border:1px solid #dee2e6,borderRadius:4px,userSelect:none,};return(div ref{setNodeRef}style{style}{...attributes}{...listeners}// 如果拖拽的模块更复杂写在这个return里{item.name}/div);};consthandleDragEnd(event){const{active,over}event;if(active.id!over?.id){setItems((items){constoldIndexitems.findIndex(itemitem.idactive.id);constnewIndexitems.findIndex(itemitem.idover.id);// 重新排列数组constnewItems[...items];const[movedItem]newItems.splice(oldIndex,1);newItems.splice(newIndex,0,movedItem);returnnewItems;});}};return(div style{{padding:20px,maxWidth:400px,margin:0 auto}}h2可拖拽列表/h2DndContext sensors{[sensor]}collisionDetection{closestCenter}onDragEnd{handleDragEnd}SortableContext items{items.map((item)item.id)}strategy{verticalListSortingStrategy}{items.map((item)(SortableItem key{item.id}item{item}/))}/SortableContext/DndContextdiv style{{marginTop:20px,fontSize:14px,color:#6c757d}}p拖拽说明:/pulli点击并拖动项目可重新排序/lili当前项目数:{items.length}/li/ul/div/div);};exportdefaultDragableList;复杂组件// 可排序列表项组件constSortableItem({item}){const{attributes,listeners,setNodeRef,transform,transition,isDragging,}useSortable({id:item.id});conststyle{transform:CSS.Transform.toString(transform),// 决定拖拽效果transition,opacity:isDragging?0.5:1,cursor:grab,padding:12px,margin:8px 0,backgroundColor:#f8f9fa,border:1px solid #dee2e6,borderRadius:4px,userSelect:none,};return(div ref{setNodeRef}style{style}{...attributes}{...listeners}TooltipPopconfirm title确定删除这条属性吗onConfirm{()deleteAttr()}conCancel{(e){console.log(e)}}Button删除/Button/Popconfirm/Tooltip/div);};

相关新闻

最新新闻

静音直流电机控制:TB9051FTG驱动与相位优化PWM技术

静音直流电机控制:TB9051FTG驱动与相位优化PWM技术

1. 为什么需要静音直流电机控制在工业自动化、家用电器和汽车电子等领域,直流电机的噪声问题一直是工程师们需要面对的挑战。传统PWM控制方式虽然简单高效,但会产生明显的电磁噪声和机械振动。以常见的12V直流减速电机为例,当采用普通H桥驱动…

2026/7/4 6:10:46
如何永久保存微信聊天记录:WeChatMsg完整导出与智能分析终极指南

如何永久保存微信聊天记录:WeChatMsg完整导出与智能分析终极指南

如何永久保存微信聊天记录:WeChatMsg完整导出与智能分析终极指南 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trendin…

2026/7/4 6:10:45
如何用AI免费提升视频画质?Video2X完整指南带你从模糊到4K超清

如何用AI免费提升视频画质?Video2X完整指南带你从模糊到4K超清

如何用AI免费提升视频画质?Video2X完整指南带你从模糊到4K超清 【免费下载链接】video2x A machine learning-based video super resolution and frame interpolation framework. Est. Hack the Valley II, 2018. 项目地址: https://gitcode.com/GitHub_Trending/…

2026/7/4 6:10:45
Video2X终极指南:如何用AI视频超分辨率让模糊视频变高清

Video2X终极指南:如何用AI视频超分辨率让模糊视频变高清

Video2X终极指南:如何用AI视频超分辨率让模糊视频变高清 【免费下载链接】video2x A machine learning-based video super resolution and frame interpolation framework. Est. Hack the Valley II, 2018. 项目地址: https://gitcode.com/GitHub_Trending/vi/vid…

2026/7/4 6:10:45
终极方案:让暗黑破坏神2在现代PC上完美运行的D2DX宽屏补丁

终极方案:让暗黑破坏神2在现代PC上完美运行的D2DX宽屏补丁

终极方案:让暗黑破坏神2在现代PC上完美运行的D2DX宽屏补丁 【免费下载链接】d2dx D2DX is a complete solution to make Diablo II run well on modern PCs, with high fps and better resolutions. 项目地址: https://gitcode.com/gh_mirrors/d2/d2dx 还在为…

2026/7/4 6:10:45
Clang AST遍历实战:通过clang-tutor学习RecursiveASTVisitor的完整指南

Clang AST遍历实战:通过clang-tutor学习RecursiveASTVisitor的完整指南

Clang AST遍历实战:通过clang-tutor学习RecursiveASTVisitor的完整指南 【免费下载链接】clang-tutor A collection of out-of-tree Clang plugins for teaching and learning 项目地址: https://gitcode.com/gh_mirrors/cl/clang-tutor 如果你正在学习Clang…

2026/7/4 6:05:45

周新闻

月新闻