首页 > 编程语言 > 详细

【前端开发】基于vue的树形结构table拖拽排序教程

时间:2021-06-25 16:53:28      阅读:15      评论:0      收藏:0      [点我收藏+]

安装依赖drag-tree-table(更多文档见github)

yarn add  drag-tree-table

html

<dragTreeTable
          ref="table"
          :data="treeData"
          @drag="onTreeDataChange"
          onlySameLevelCanDrag
          resize
          fixed
          :isdraggable="true"
        >
          <template #selection="{row}">
            {{ row.menuName }}
          </template>
          <template #icon="{row}">
            <svg-icon :icon-class="row.icon" />
          </template>
          <template #visible="{row}">
            <div @click.stop>
              <el-switch
                @change="
                  val => {
                    visiableChange(val, row)
                  }
                "
                v-model="row.visible"
                active-value="0"
                inactive-value="1"
              />
            </div>
          </template>
          <template #edit="{row}">
            <el-button
              v-hasPermi="[‘system:menu:edit‘]"
              type="text"
              icon="el-icon-edit"
              @click.stop.prevent="handleUpdate(row)"
              >编辑</el-button
            >
            <el-button
              v-hasPermi="[‘system:menu:add‘]"
              type="text"
              icon="el-icon-plus"
              @click.stop.prevent="handleAdd(row)"
              >新增</el-button
            >
            <el-button
              v-hasPermi="[‘system:menu:remove‘]"
              class="btn-delete"
              type="text"
              icon="el-icon-delete"
              @click.stop.prevent="handleDelete(row)"
              >删除</el-button
            >
          </template>
        </dragTreeTable>

 

js

import dragTreeTable from ‘drag-tree-table‘

@Component({
  name: ‘MenuManage‘,
  components: {
    dragTreeTable
  }
})

private tableIdArr: Array<string> = []
private treeData: any = {
    lists: [],
    columns: [
      {
        type: ‘selection‘,
        title: ‘菜单名称‘,
        field: ‘menuName‘,
        width: 130,
        align: ‘left‘
      },
      {
        type: ‘icon‘,
        title: ‘图标‘,
        field: ‘icon‘,
        width: 100
      },
      // {
      //   title: ‘排序‘,
      //   field: ‘orderNum‘,
      //   width: 60
      // },
      {
        title: ‘权限标识‘,
        field: ‘perms‘,
        width: 130
      },
      {
        title: ‘组件路径‘,
        field: ‘component‘,
        width: 180
      },
      {
        type: ‘visible‘,
        title: ‘可见‘,
        field: ‘visible‘,
        width: 80
      },
      {
        title: ‘创建时间‘,
        field: ‘createTime‘,
        width: 180
      },
      {
        type: ‘edit‘,
        title: ‘操作‘,
        field: ‘‘,
        width: 200,
        align: ‘center‘
      }
    ]
}

拖拽方法

  // 树形table拖拽排序
  onTreeDataChange(list: Array<object>, curObj: any) {
    this.treeData.lists = list // 拖拽后的数据
    this.tableIdArr = []
    // const idArr = this.filterIdArrFun(JSON.parse(JSON.stringify(list)), curObj.parent_id)
    const putData = {
      parentId: curObj.parent_id, // 父目录id
      ids: this.tableIdArr  // 同级id
    }
// 得到父id和同级id数组即可请求接口
} /** 递归获取父级id相同对象的id数组 **/ filterIdArrFun(data: any, parentId: string) { const firstFun = data.map((q: any) => { if (q.lists && q.lists.length > 0) { if (q.parentId == parentId) { this.tableIdArr.push(q.id) } q.lists = this.filterIdArrFun(JSON.parse(JSON.stringify(q.lists)), parentId) } else { if (q.parent_id === parentId) { this.tableIdArr.push(q.id) } } return q }) return this.tableIdArr }

 

效果
技术分享图片

 

 

【前端开发】基于vue的树形结构table拖拽排序教程

原文:https://www.cnblogs.com/xiaohuizhang/p/14931211.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!