第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定

實現(xiàn)拖拽復(fù)制和可排序的react.js組件

標(biāo)簽:
Html5 React.JS

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

  1. 摒弃了value中的content属性,拖拽组件暴露的render函数,利用这个属性进行组件内部子组件的渲染,这点主要是参考了蚂蚁金服的Ant design里面一些组件的设计。

  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地址:https://github.com/VicEcho/VD...

原文链接:https://segmentfault.com/a/1190000016064061

點擊查看更多內(nèi)容
1人點贊

若覺得本文不錯,就分享一下吧!

評論

作者其他優(yōu)質(zhì)文章

正在加載中
感謝您的支持,我會繼續(xù)努力的~
掃碼打賞,你說多少就多少
贊賞金額會直接到老師賬戶
支付方式
打開微信掃一掃,即可進行掃碼打賞哦
今天注冊有機會得

100積分直接送

付費專欄免費學(xué)

大額優(yōu)惠券免費領(lǐng)

立即參與 放棄機會
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號

舉報

0/150
提交
取消