react-beautiful-dnd组件报Unable to find draggable with id

一、问题现象

项目中使用react-beautiful-dnd组件实现可拖拽,但拖了1次后可能会出现拖拽异常(元素拖不动),打开控制台会发现有报错
在这里插入图片描述

二、解决方案

给Draggable组件和其下方的div添加了key就正常了,以下是我自己简单写的一个demo,可供参考


import { useState } from 'react'
import { DragDropContext, Droppable, Draggable } from 'react-beautiful-dnd';
import './App.css'

const mocklist = [
  {
    label: 'item11',
    id:'aa',
    value: 'aa',
    color: 'red'
  },
  {
    label: 'item22',
    value: 'bb',
    id:'bb',
    color: 'blue'
  },
  {
    label: 'item33',
    value: 'cc',
    id:'cc',
    color: 'yellow'
  },
  {
    label: 'item44',
    value: 'dd',
    id:'dd',
    color: 'pink'
  },
  {
    label: 'item55',
    value: 'ee',
    id:'ee',
    color:'green'
  },
]
function App() {

  const [list,setList] =useState(mocklist);

  // 重新排序-更新列表
  const reorder = (list, startIndex, endIndex) => {
    const result = [...list];
    const [removed] = result.splice(startIndex, 1);
    result.splice(endIndex, 0, removed);
    return result;
  };

  // 拖拽结束
  const onDragEnd =(result)=>{
    if (!result.destination) {
      return;
    }
    if (result.destination.index === result.source.index) {
      return;
    }
    const newList = reorder(
      list,
      result.source.index,
      result.destination.index,
    );
    setList(newList)
  }

  return (
    <div>
      <DragDropContext onDragEnd={onDragEnd}>
      <div>
        <Droppable droppableId="list" key="list">
          {provided => (
            <div ref={provided.innerRef} {...provided.droppableProps}>
              {
              list.map((item, index) => {
                return (
                  <Draggable draggableId={item.id} index={index} key={item.id}>
                    {provided => (
                      <div
                        ref={provided.innerRef}
                        key={item.value}
                        {...provided.draggableProps}
                        {...provided.dragHandleProps}
                      >
                        <div style={{ marginBottom: 10,backgroundColor:item.color }}>
                          {item.label}
                        </div>
                      </div>
                    )}
                  </Draggable>
                );
              })
            }
              {provided.placeholder}
            </div>
          )}
        </Droppable>
      </div>
    </DragDropContext>
    </div>
  )
}

export default App

三、备注

注意:貌似这个组件在vite脚手架起的项目中会有问题(元素不能被拖拽),亲测在react脚手架ok

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
react-beautiful-dnd是一个用于实现拖放功能的React库。它提供了一个优雅的方式来实现复杂的拖放交互,并且在性能方面也表现出色。 官方示例展示了如何在React中使用react-beautiful-dnd来创建一个基本的拖放列表。该示例使用两个列表,左侧列表中有一些颜色方块,右侧列表为空。 首先,我们需要引入所需的库和组件。然后,在页面上创建两个容器,一个用于左侧列表,一个用于右侧列表。接下来,我们需要定义一个状态来存储列表项的数据。在示例中,数据是一个包含颜色方块的数组。我们还需要定义一个函数来处理列表项的拖动和放置操作。 然后,我们可以使用react-beautiful-dnd提供的DragDropContext组件来包裹整个应用,并将其附加到页面的根元素上。这样可以确保拖放操作在整个应用中生效。 接下来,我们需要在左侧列表容器中渲染颜色方块列表,并使用Draggable组件对每个方块进行包装。我们还需要在Draggable组件上设置一个唯一的ID,并使用DragHandleProps和DraggableProps来传递拖动和放置操作的属性。 最后,我们需要在右侧列表容器中渲染一个Droppable组件,以表示可以将颜色方块拖放到其中。并且,我们需要在Droppable组件上使用DroppableProps来传递拖放操作的属性。 通过以上步骤,我们就可以创建一个简单的拖放列表。当我们拖动一个颜色方块时,react-beautiful-dnd会自动处理其它方块的重新排序和位置更新。同时,我们还可以添加一些自定义的逻辑来实现更复杂的拖放交互效果。 总之,react-beautiful-dnd官方示例展示了如何使用这个库来创建一个基本的拖放列表。通过这个示例,我们可以学习到如何在React中使用react-beautiful-dnd,并了解其强大的拖放功能和灵活的配置选项。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Ronychen’s blog

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值