ant design vue a-table实现拖拽排序

本文介绍了如何在Vue3项目中重构React的菜单配置列表功能,使用AntDesignVue组件库遇到付费拖拽功能的问题,并详细展示了如何手动实现表格行的拖拽排序功能。通过监听鼠标事件,实现拖拽开始、结束时的数据交换及接口调用来完成排序更新。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近在把react项目使用vue3进行重构,vue项目组件库使用ant design vue。

重构的功能包括:

1,M站菜单配置列表的展示

2,菜单列表新增

3,菜单列表的编辑

4,列表的拖拽排序

阅读ant design vue文档看到有table拖拽功能,准备直接使用,此处埋下彩蛋一颗

顺利的重构了1,2,3功能之后,照着文档配置好拖拽属性发现不生效

,翻阅源码没有找到对应的配置代码,原来拖拽功能属于付费内容,一年4999,ops~(ps:支持知识付费哈~但是我穷)

那就只能自己手写功能4了

梳理思路如下:

1,鼠标移入table行,修改改行gragable=true,修改鼠标展示样式为move

2,添加dragstart事件,在该事件中记录sourceRecord数据

3,添加dragend事件,在该事件中记录targetRecord数据

4,整体list数据中交换这两条数据,更新list

ant design vue a-table提供了customRow属性

该属性可以对每一行添加对应的样式,事件,为我们的实现思路打开了缺口。

最后代码如下:

<a-table
      :columns="columns"
      :data-source="data"
      :pagination="false"
      :customRow="customRow"
      @row-drag-end="onRowDragEnd"
    >
      <template #bodyCell="{ column, text, record }">
        <template v-if="column.dataIndex === 'weight'">
          {{ ++text }}
        </template>
        <template v-if="column.dataIndex === 'navName'">
          <div :title="record.navName" class="overflowdiv">
            {{ record.navName }}
          </div>
        </template>
        <template v-if="column.dataIndex === 'iconUrl'">
          <img class="appMenu-icon-img" :src="text" />
        </template>
        <template v-if="column.dataIndex === 'status'">
          {{ text ? "已启用" : "未启用" }}
        </template>
        <template v-if="column.dataIndex === 'operatorName'">
          <div :title="record.operatorName" class="overflowdiv">
            {{ record.operatorName }}
          </div>
        </template>
        <template v-if="column.dataIndex === 'updateTime'">
          {{ text ? text : record.createTime }}
        </template>
        <template v-if="column.dataIndex === 'operation'">
          <span class="appMenu-operation-span">
            <span @click="() => this.handleEdit(record)"
              >编辑<a-divider type="vertical"></a-divider
            ></span>
            <span @click="() => handleEnableMenu(record)">{{
              record.status ? "禁用" : "启用"
            }}</span>
          </span>
        </template>
      </template>
    </a-table>
<script>
methods: {
    customRow(record, index) {
      console.log(record, index);
      return {
        style: {
          cursor: "move",
        },
        // 鼠标移入
        onMouseenter: (event) => {
          // 兼容IE
          var ev = event || window.event;
          ev.target.draggable = true;
        },
        // 开始拖拽
        onDragstart: (event) => {
          // 兼容IE
          var ev = event || window.event;
          // 阻止冒泡
          ev.stopPropagation();
          // 得到源目标数据
          this.sourceObj = record;
        },
        // 拖动元素经过的元素
        onDragover: (event) => {
          // 兼容 IE
          var ev = event || window.event;
          // 阻止默认行为
          ev.preventDefault();
        },
        // 鼠标松开
        onDrop: (event) => {
          // 兼容IE
          var ev = event || window.event;
          // 阻止冒泡
          ev.stopPropagation();
          // 得到目标数据
          this.targetObj = record;
          console.log(this.sourceObj, this.targetObj);
          const tempDta = this.data;
          tempDta[this.targetObj.weight] = this.sourceObj;
          tempDta[this.sourceObj.weight] = this.targetObj;
          let weightList = [];
          tempDta.forEach((item, index) => {
            item.weight = index;
            weightList.push({
              id: item.id,
              weight: index,
            });
          });
          this.handleWeightModify(weightList);// 更改顺序接口
        },
      };
    }
}
</script>

至此,拖拽排序table顺利重构完成。

Ant Design Vue 提供了一个可以实现拖拽排序的组件 - `<a-draggable>`。 使用方法如下: 1. 首先安装 `ant-design-vue`: ``` npm install ant-design-vue --save ``` 2. 在需要使用的组件中引入 `a-draggable`: ```vue <template> <div> <a-draggable class="drag-wrapper" :list="list" :item-key="item => item.id"> <div v-for="item in list" :key="item.id" class="drag-item">{{ item.content }}</div> </a-draggable> </div> </template> <script> import { ADraggable } from 'ant-design-vue'; export default { components: { ADraggable, }, data() { return { list: [ { id: 1, content: 'Item 1' }, { id: 2, content: 'Item 2' }, { id: 3, content: 'Item 3' }, { id: 4, content: 'Item 4' }, ], }; }, }; </script> ``` 在上面的示例中,我们首先引入了 `ADraggable` 组件,并将其注册到当前组件中。然后在模板中使用 `a-draggable` 标签包裹要进行拖拽排序的元素,其中 `list` 是要排序的数据列表,`item-key` 属性用来指定每个元素的唯一标识符。 在 `a-draggable` 组件内部,我们使用 `v-for` 指令遍历 `list` 中的数据,并将每个元素渲染为一个 `div` 标签。这里要注意,我们给每个 `div` 标签指定了 `key` 属性,这样可以帮助 Vue 更好地追踪每个元素的变化。 最后,在样式中定义好拖拽排序元素的样式即可: ```css .drag-wrapper { display: flex; flex-wrap: wrap; margin-bottom: 20px; } .drag-item { width: 200px; height: 100px; background-color: #f5f5f5; border: 1px solid #ddd; border-radius: 4px; margin-right: 20px; margin-bottom: 20px; display: flex; align-items: center; justify-content: center; font-size: 16px; font-weight: bold; } ``` 这样就实现了一个简单的拖拽排序功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值