最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

react.js组件实现拖拽复制和可排序的示例代码

来源:动视网 责编:小采 时间:2020-11-27 22:09:36
文档

react.js组件实现拖拽复制和可排序的示例代码

react.js组件实现拖拽复制和可排序的示例代码:在实现复制前,对之前的拖拽排序组件属性进行了修改。 摒弃了value中的content属性,拖拽组件暴露的render函数,利用这个属性进行组件内部子组件的渲染,这点主要是参考了蚂蚁金服的Ant design里面一些组件的设计。 为了实现Data和model的脱藕,和
推荐度:
导读react.js组件实现拖拽复制和可排序的示例代码:在实现复制前,对之前的拖拽排序组件属性进行了修改。 摒弃了value中的content属性,拖拽组件暴露的render函数,利用这个属性进行组件内部子组件的渲染,这点主要是参考了蚂蚁金服的Ant design里面一些组件的设计。 为了实现Data和model的脱藕,和


在实现复制前,对之前的拖拽排序组件属性进行了修改。

  • 摒弃了value中的content属性,拖拽组件暴露的render函数,利用这个属性进行组件内部子组件的渲染,这点主要是参考了蚂蚁金服的Ant design里面一些组件的设计。
  • 为了实现Data和model的脱藕,和sortKey一样,组件增加codeKey属性。
  • 拖拽复制的效果如下:

    由于实现组件的核心是根据value数据来渲染页面,因此实现拖拽复制功能,只需要在“拖拽释放”的时候,将被拖拽方的数据放到当前目标所在的value数组中即可。

    具体实现代码如下:

    // 当一个元素或是选中的文字被拖拽释放到一个有效的释放目标位置时
     drop(dropedSort, data, sortKey, dropedUid, codeKey, ee) {
     ee.preventDefault();
     const code = ee.dataTransfer.getData("code");
     const uId = ee.dataTransfer.getData("uId");
     const dragedItem = ee.dataTransfer.getData("item");
     const sort = ee.dataTransfer.getData("sort");
     if (uId === dropedUid) {
     if (sort < dropedSort) {
     data.map(item => {
     if (item[codeKey] === code) {
     item[sortKey] = dropedSort;
     } else if (item[sortKey] > sort && item[sortKey] < dropedSort + 1) {
     item[sortKey]--;
     }
     return item;
     });
     } else {
     data.map(item => {
     if (item[codeKey] === code) {
     item[sortKey] = dropedSort;
     } else if (item[sortKey] > dropedSort - 1 && item[sortKey] < sort) {
     item[sortKey]++;
     }
     return item;
     });
     }
     } else if (this.props.isAcceptAdd) {
     let objDragedItem = JSON.parse(dragedItem);
     if (data.filter(item => item[codeKey] === objDragedItem[codeKey]).length === 0) {
     const maxSort = Math.max.apply(Math, data.map(citem => citem[sortKey]));
     data.map(item => {
     if (dropedSort === maxSort) {
     objDragedItem[sortKey] = dropedSort + 1;
     } else {
     if (item.sort > dropedSort) {
     objDragedItem[sortKey] = dropedSort + 1;
     item[sortKey]++
     }
     }
     return item
     });
     data.push(objDragedItem)
     }
     }
     this.props.onChange(data)
     if (ee.target.className.indexOf('droppingContent') !== -1) {
     ee.target.className = styles.droppedcontent;
     }
     }

    这里要注意的有两点:

    第一点是,我通过this.props.isAcceptAdd这个属性来判断当前组件是否允许接受拖拽复制的元素。

    第二点是,我有一个放在内存中的“uId”,这个“uId”在每个拖拽组件初始化的时候生成。这样我就可以通过它来判断,当前被拖拽到目标区域的元素,是组件本身的内部元素还是外部元素,如果是内部就执行排序功能,外部则执行复制的逻辑代码。

    组件API:


    GitHub地址:https://github.com/VicEcho/VDraggable

    文档

    react.js组件实现拖拽复制和可排序的示例代码

    react.js组件实现拖拽复制和可排序的示例代码:在实现复制前,对之前的拖拽排序组件属性进行了修改。 摒弃了value中的content属性,拖拽组件暴露的render函数,利用这个属性进行组件内部子组件的渲染,这点主要是参考了蚂蚁金服的Ant design里面一些组件的设计。 为了实现Data和model的脱藕,和
    推荐度:
    • 热门焦点

    最新推荐

    猜你喜欢

    热门推荐

    专题
    Top