博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
实现拖拽复制和可排序的react.js组件
阅读量:6005 次
发布时间:2019-06-20

本文共 2503 字,大约阅读时间需要 8 分钟。

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

  1. 摒弃了value中的content属性,拖拽组件暴露的render函数,利用这个属性进行组件内部子组件的渲染,这点主要是参考了蚂蚁金服的里面一些组件的设计。
  2. 为了实现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地址:

转载地址:http://wipmx.baihongyu.com/

你可能感兴趣的文章
Oracle 创建表空间
查看>>
JAVA下实现二叉树的先序、中序、后序、层序遍历(递归和循环)
查看>>
采集技术网址
查看>>
Spring JDBC 例子
查看>>
网上下载的 chm 文件打开后右侧内容显示空白
查看>>
MySQL——SQL Mode详解
查看>>
淡入淡出特效
查看>>
ThinkPHP CURD操作
查看>>
Duilib自定义控件响应指定命令(转载)
查看>>
Zabbix 监控 Nginx(四)
查看>>
drop user ora-604 ora-54
查看>>
ABAP WB01 BDC ”No batch input data for screen & &“ ”没有屏幕 & & 的批输入数据“
查看>>
JavaScript闭包的应用案例——让Onclick事件都能正确的弹出相应的参数
查看>>
边界测试——让BUG现形
查看>>
16个Javascript的Web UI库、框架及工具包
查看>>
[学习链接]infoQ与腾讯大讲堂
查看>>
吃知了有什么好处
查看>>
【AS3代码】数组知识
查看>>
【IBM Tivoli Identity Manager 学习文档】13 Service管理
查看>>
Oracle DB 备份和恢复的概念
查看>>