【发布时间】:2016-02-16 23:00:06
【问题描述】:
我已调整 react-dnd sortable example 以在我的应用程序内部使用。
我无法使“不透明度”跟随我的拖动。
当我最初拾取元素时应用不透明度:
但是当我将它向上移动以更改位置时,不透明度仍然应用于原始 DOM 元素(?)。
状态相应更改,与此状态关联的表中的列正在重新排序。所以除了不透明度之外,其他一切都很好。
当我移动元素时,只有 li 的值被改变,但 data-reactid 没有改变位置。
我的应用程序的唯一区别是我管理状态的方式。在我的应用程序中,状态是通过 redux 管理的。
传入 DropTarget 的 hover 函数基本上是示例中的复制和粘贴。
SortableColumnEntry 组件:
class SortableColumnEntry extends Component {
render(){
const { connectDragSource, connectDropTarget } = this.props
const { column, isDragging, index } = this.props
const opacity = isDragging ? 0 : 1
const element = connectDropTarget(connectDragSource(
<li
style={{opacity: opacity}}</li>
))
return element
}
}
export default flow(
DragSource(DragTypes.COLUMN, source, (connect, monitor) => ({
connectDragSource: connect.dragSource(),
isDragging: monitor.isDragging()
})),
DropTarget(DragTypes.COLUMN, target, (connect) => ({
connectDropTarget: connect.dropTarget()
}))
)(SortableColumnEntry)
【问题讨论】:
标签: drag-and-drop reactjs redux react-dnd