antd——a-tree组件拖拽节点功能——技能提升

之前写过一篇文章关于:

antd——使用a-tree组件实现 检索+自动展开+自定义增删改查功能——技能提升:http://t.csdn.cn/13qT7

效果图

在这里插入图片描述
现在有个需求:就是要实现节点的拖拽功能。

tree组件节点的拖拽功能实现

tree组件是有拖拽功能的,通过下面几种拖拽方式来进行汇总规律:

1.同级别拖拽——最终位置是10,目标节点位置是11,小于代表在上面

在这里插入图片描述

2.子级拖拽——最终位置是7,目标节点位置是7,表示是成为目标节点的子级

在这里插入图片描述

3.跨级别拖拽——最终位置是-1,目标节点位置是0,小于代表在上面

在这里插入图片描述
三张图中的位置0-7-0,是代表的是索引。

1.第一个:0代表是外层数组只有一项,索引是0
2.第二个:7代表是当前是索引为7的子级
3.第三个:0代表是索引为7的子级的第0项

代码如下:

html代码

<a-tree
  ref="treeNode"
  :showIcon="false"
  class="tree-list"
  draggable
  :treeData="treeData"
  :defaultExpandAll="true"
  :expandedKeys.sync="defaultExpandedKeys"
  tree-default-expand-all
  :replaceFields="replaceFields"
  @dragenter="onDragEnter"
  @drop="onDrop"
></a-tree>

js代码

onDragEnter(info) {
      // console.log('onDragEnter', info);
    },
    onDrop(info) {
      const dropKey = info.node.eventKey;
      const dragKey = info.dragNode.eventKey;
      console.log(
        '目标节点',
        info.node.pos,
        info.node.dataRef.title,
        info.dropPosition
      );
      console.log(
        '当前节点',
        info.dragNode.pos,
        info.dragNode.dataRef.title,
        info.dropPosition
      );
      //当前拖拽的节点key dragKey;
      const dropPos = info.node.pos.split('-');
      const dropPosition =
        info.dropPosition - Number(dropPos[dropPos.length - 1]);
      const loop = (data, key, callback) => {
        data.forEach((item, index, arr) => {
          if (item.key === key) {
            return callback(item, index, arr);
          }
          if (item.children) {
            return loop(item.children, key, callback);
          }
        });
      };
      const data = [...this.treeData];
      let dragObj;
      loop(data, dragKey, (item, index, arr) => {
        arr.splice(index, 1);
        dragObj = item;
      });
      if (!info.dropToGap) {
        // Drop on the content
        loop(data, dropKey, (item) => {
          item.children = item.children || [];
          // where to insert 示例添加到尾部,可以是随意位置
          item.children.push(dragObj);
        });
      } else if (
        (info.node.children || []).length > 0 && // Has children
        info.node.expanded && // Is expanded
        dropPosition === 1 // On the bottom gap
      ) {
        loop(data, dropKey, (item) => {
          item.children = item.children || [];
          // where to insert 示例添加到尾部,可以是随意位置
          item.children.unshift(dragObj);
        });
      } else {
        let ar;
        let i;
        loop(data, dropKey, (item, index, arr) => {
          ar = arr;
          i = index;
        });
        if (dropPosition === -1) {
          ar.splice(i, 0, dragObj);
        } else {
          ar.splice(i + 1, 0, dragObj);
        }
      }
      //在此处可以调取接口,接口成功后,再给treeData赋值,否则就不要赋值。
      this.treeData = data;
    },

完成!!!多多积累,多多收获!

下面的内容跟文章相关不大,仅为了凑字数,可忽略!!!

拖动属性dropToGap,dropPosition
属性解释:
dropToGap:
boolean类型,true代表拖拽到节点之间的缝隙中,false代表拖拽到节点上,即节点的内容区。

dropPosition:
拖拽的时候,针对一个节点有三种情况,即拖拽到节点之上,拖拽到节点上,拖拽到节点之下。
三种情况其值有所不同。antd 依赖了 rc-tree,在 rc-tree 里 dropPosition 是一个相对地址。
如果拖到了目标节点的上面则当前元素 -1,下面则是 1(* rc-tree这块不确定具体情况*)。

antd 里则是相对于目标节点的 index针对拖动情况计算出来。
拖拽到节点之上: 该节点的 index-1
拖拽到节点上:dropPosition 就是该节点的 index。
拖拽到节点之下:该节点的 index+1

在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 4
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

叶浩成520

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值