el-tree实现同一级排序

<el-tree
  :data="data"
  :props="defaultProps"
  node-key="id"
  draggable
  :allow-drop="allowDrop"
  @node-drop="handleDrop"
/>

data() {
  return {
    data: [
      {id:'001',name:'名称'},
      {id:'002',name:'类型'},
      {id:'003',name:'备注'}
    ],
    defaultProps: {
      label: 'name'
    },
    list: { assetFieldIds: [] }
  }
},


methods: {
  // 只允许同一级之间拖拽排序
  allowDrop(draggingNode, dropNode, type) {
    if (draggingNode.level === dropNode.level) {
      if (draggingNode.data.parentId === dropNode.data.parentId) {
        return type === 'prev' || type === 'next'
      }
    } else {
      return false
    }
  },
  // 拖拽完成时触发的事件
  handleDrop(draggingNode, dropNode, dropType, ev) {
    for (const item of dropNode.parent.childNodes) {
      this.list.assetFieldIds.push(item.data.id)
      // this.list是排序后的id数组,id是因为node-key='id'
    }
  },
  funGetDragSort() {
    //利用this.list请求接口
  }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值