- 28
- 0
问题描述
react dnd插件中拖拽目标组件中spec的props.index一直是undefined,这个要如何才能获取到该值?
问题出现的环境背景及自己尝试过哪些方法
使用React dnd 实现React项目的拖拽功能,在拖拽目标组件(Target)中,在hover(props, monitor, component) 组件中获取specObj 对象方法中的props.index一直为undefined。
百度文档中描述props: 组件当前的props
个人也采用了在拖拽目标组件(Target.js)模板中给子组件传了index
相关代码
...
const cardTarget = {
hover(props, monitor) {
console.log('props-->',props.index); //在控制台打印出来是undefined
//问题:我要如何才能获取到这个值?
}
};
class Target extends Component {
render() {
....
let items = list.map((item, index) => {
return <Source index={index} id={item.id} />
})
return connectDropTarget(<div>{items}</div>)
}
}
...
你期待的结果是什么?实际看到的错误信息又是什么?
在hover组件中如何才能获取到specObj 对象方法中的props.index的值?
控制台打印信息:
props index--> undefined
- 共 0 条
- 全部回答
-
橘子味的︴小宝贝≧o≦ 普通会员 1楼
在React中,你可以使用React Query的useEffect钩子来获取React组件的props.index。下面是一个例子:
```jsx import { useEffect, useState } from 'react';
function useDraggable(index) { const [draggable, setDraggable] = useState(null);
useEffect(() => { const dragged = document.getElementById(
draggable-${index}); const handleDragStart = (event) => { setDraggable(event.target); };const handleDragEnd = () => { setDraggable(null); }; document.addEventListener('dragstart', handleDragStart); document.addEventListener('dragend', handleDragEnd); return () => { document.removeEventListener('dragstart', handleDragStart); document.removeEventListener('dragend', handleDragEnd); };}, [index]);
return draggable; }
export default useDraggable; ```
在这个例子中,我们创建了一个useEffect钩子,它会在拖动开始和结束时执行。在拖动开始时,它会获取拖动的目标元素,并将其设置为Draggable的引用。在拖动结束时,它会删除Draggable的引用。
然后,我们在组件的state中使用Draggable来表示是否拖动某个元素。这可以通过调用useEffect钩子来实现。
注意,你需要将
draggable和index替换为你的实际组件和拖动的目标组件的引用。
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部

