rbd入坑指南

react-beautiful-dnd[drop and drag]入坑指南

Beautiful and accessible drag and drop for lists with React

相关链接:


React拖拽库调研

  • react-beautiful-dnd 23.9k⭐
  • react-dnd 15.9K⭐
  • react-grid-layout 13.7⭐
  • react-dropzone 8.2⭐
  • react-draggable 6.8k⭐
  • react-smooth-dnd 1.5k⭐

库分析

react-dnd:
两种使用方式:钩子函数 装饰器

react-beautiful-dnd:
组件


react-beautiful-dnd使用分3步走


  1. 设置拖拽根上下文
class App extends Component {
    onDragEnd(result) {
        if (result.destination) {
            // doSomething
        }
    }

    render() {
        return (
            <DragDropContext onDragEnd={this.onDragend}>
                {this.props.children}
            </DragDropContext>
        )
    }
}

onDragEnd事件中的result参数:
drag end result


  1. 设置Droppable父组件
<Droppable
    droppableId="ComList"
    isDropDisabled={true}
    renderClone={(provided, snapshot, rubric) => {
    const name = rubric.draggableId.split('-')[1]
    const PreviewComp = getPreviewComponent(name, {
        inlineStyle: {
            border: '1px dashed #e02200',
            backgroundColor: 'rgba(255, 255, 255, .75)'
        }
    })
    return (
        <div
        {...provided.draggableProps}
        {...provided.dragHandleProps}
        ref={provided.innerRef}
        >
        {PreviewComp}
        </div>
    )
    }}
>
    {(provided, snapshot) => (
    <div {...provided.droppableProps} ref={provided.innerRef}>
        <ComList />
        {provided.placeholder}
    </div>
    )}
</Droppable>

  1. 设置Draggable子组件
<Draggable
    draggableId={`ComItem-${this.props.name}-${this.props.index}`}
    index={this.props.index}
    isDragDisabled={false}
>
    {(provided, snapshot) => (
    <div
        ref={provided.innerRef}
        {...provided.draggableProps}
        {...provided.dragHandleProps}
        className={c(s.wrapper, !addable && s.disable)}
        onClick={this.add}
    >
        <CurrentIcon style={{ fontSize: '20px' }} />
        {userName}
    </div>
    )}
</Draggable>

坑点

  1. 通常只需要一个DragDropContext组件
  2. Draggable组件必须是Droppable组件的子组件
  3. DraggabledraggableId属性必须保证在Droppable父组件下唯一, index属性表明当前组件的顺序,也唯一。这个属性会在onDragEnd事件结果中有所体现
  4. Droppable组件内的Draggable组件不需要拖拽特性,可以设置Draggable组件的isDragDisabled属性为true
  5. 可以设置Droppable组件的renderClone属性自定义拖拽视图

END

### 关于华为OD机考A的知识点总结 #### 1. 题目构成与分布 根据以往的经验,华为OD机考试题通常会分为多个部分,每部分考察不同的技能和知识点。对于A而言,其题目可能来源于历年积累的经典算法问题以及实际工程中的应用案例[^1]。 #### 2. 数据结构基础 数据结构是华为OD机考的核心考点之一,在A中可能会涉及栈、队列、链表等基本数据结构的应用。例如,考生需熟练掌握如何实现双向链表的增删改查操作或者利用堆栈解决括号匹配等问题[^4]。 ```python class Node: def __init__(self, data=None): self.data = data self.next = None def reverse_linked_list(head): prev = None current = head while(current is not None): next_node = current.next current.next = prev prev = current current = next_node return prev ``` 上述代码展示了反转单向链表的一个简单例子。 #### 3. 序与查找算法 序和查找也是不可忽视的重要环节。快速序、归并序及其时间复杂度分析经常作为笔试的重点内容出现;而二分法则是高效检索的关键技巧[^2]。 ```c++ void mergeSort(int arr[], int l, int r){ if(l &gt;= r) return; int m = (l+r)/2; mergeSort(arr,l,m); mergeSort(arr,m+1,r); // 合并两个有序数组 vector&lt;int&gt; temp(r-l+1); int i=l,j=m+1,k=0; while(i&lt;=m &amp;&amp; j&lt;=r){ if(arr[i]&lt;arr[j]) temp[k++]=arr[i++]; else temp[k++]=arr[j++]; } while(i&lt;=m) temp[k++]=arr[i++]; while(j&lt;=r) temp[k++]=arr[j++]; for(int p=0;p&lt;temp.size();p++) arr[l+p]=temp[p]; } ``` 此段C++程序实现了经典的归并序方法。 #### 4. 字符串处理能力 字符串相关的题目往往考验选手对细节的关注程度。比如模式匹配(KMP算法),子序列判断等功能都需要扎实的基础才能顺利完成解答[^3]。 #### 5. 动态规划初步理解 动态规划虽然属于较难的部分,但在某些特定场景下仍会被提及。像斐波那契数列计算这样的入门级DP问题就有可能出现在试当中。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值