Element ui表格行、列拖拽

方式一:

1、首先安装vuedraggable插件或直接安装sortablejs

npm i -S vuedraggable
npm i sortablejs --save

2、更多属性配置参考中文文档:vue.draggable中文文档 - itxst.com
3、在需要配置的页面引入

import Sortable from 'sortablejs';

4、要点:
4.1、先找到拖拽元素的父容器

4.2、行拖拽:在 el-table 标签中,根据行的内容指定行的唯一标识 row-key=“id”

4.3、列拖拽:额外定义两个数组,分别存储拖拽前的列顺序和拖拽后的列顺序

完整代码
<template>
    <div class="draggable" style="padding: 20px">
        <el-table
                row-key="id"
                :data="dataList"
                style="width: 100%"
                border
        >
            <el-table-column
                    v-for="(item,index) in oldList"
                    :key="`col_${index}`"
                    :prop="newList[index].prop"
                    :label="item.label"
                    align="center"
            >
            </el-table-column>
        </el-table>
    </div>
</template>
<script>
    import Sortable from 'sortablejs';
    export default {
        mounted() {
            this.oldList = JSON.parse(JSON.stringify(this.tableConfig.tableItems))
            this.newList = JSON.parse(JSON.stringify(this.tableConfig.tableItems))
            this.columnDrop()
            this.rowDrop()
        },
        data() {
            return {
                oldList: [],
                newList: [],
                dataList: [
                    {
                        id:1,
                        name:'温度',
                        type:'℃',
                        value:10,
                    },
                    {
                        id:2,
                        name:'PM2.5',
                        type:'ug/m3',
                        value:20,
                    },
                    {
                        id:3,
                        name:'PM10',
                        type:'ug/m3',
                        value:30,
                    },
                ],
                tableConfig: {
                    tableItems: [
                        {
                            label: '名称',
                            prop: 'name',
                        },
                        {
                            label: '类型',
                            prop: 'type',
                        },
                        {
                            label: '值',
                            prop: 'value',
                        }
                    ]
                }
            }
        },
        methods: {
            // 行拖拽
            rowDrop() {
                // 此时找到的元素是要拖拽元素的父容器
                const tbody = document.querySelector('.draggable .el-table__body-wrapper tbody');
                const _this = this;
                Sortable.create(tbody, {
                    //  指定父元素下可被拖拽的子元素
                    draggable: ".draggable .el-table__row",
                    onEnd({newIndex, oldIndex}) {
                        const currRow = _this.dataList.splice(oldIndex, 1)[0];
                        _this.dataList.splice(newIndex, 0, currRow);
                    }
                });
            },
            // 列拖拽
            columnDrop() {
                const wrapperTr = document.querySelector('.draggable .el-table__header-wrapper tr');
                this.sortable = Sortable.create(wrapperTr, {
                    animation: 180,
                    delay: 0,
                    onEnd: evt => {
                        const oldItem = this.newList[evt.oldIndex];
                        this.newList.splice(evt.oldIndex, 1);
                        this.newList.splice(evt.newIndex, 0, oldItem);
                    }
                });
            }
        }
    }
</script>
<style scoped>
</style>

方式二:

<template>
  <div class="hello">
    <!-- 拖拽功能必须绑定row-key唯一 -->
    <el-table
      ref="dragTable"
      :data="tableData"
      style="width: 100%"
      row-key="id"
    >
      <el-table-column prop="date" label="日期" width="180"> </el-table-column>
      <el-table-column prop="name" label="姓名" width="180"> </el-table-column>
      <el-table-column prop="address" label="地址"> </el-table-column>
    </el-table>
  </div>
</template>

<script>
import { Table, TableColumn } from 'element-ui'
// 引用第三方拖拽插件
import Sortable from 'sortablejs'
export default {
  name: 'HelloWorld',
  components: {
    ElTable: Table,
    ElTableColumn: TableColumn
  },
  data () {
    return {
      tableData: [
        {
          id: 0,
          date: '2016-05-02',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        },
        {
          id: 1,
          date: '2016-05-04',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1517 弄'
        },
        {
          id: 2,
          date: '2016-05-01',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1519 弄'
        },
        {
          id: 3,
          date: '2016-05-03',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1516 弄'
        }
      ],
      sortable: null,
      newList: []
    }
  },
  mounted () {
   //这里我是在mounted中调用了拖拽方法,一般获取到表格数据后nextTick中就可以调用拖拽方法
    this.setSort()
  },
  methods: {
    setSort () {
      const el = this.$refs.dragTable.$el.querySelectorAll(
        '.el-table__body-wrapper > table > tbody'
      )[0]
      this.sortable = Sortable.create(el, {
        ghostClass: 'sortable-ghost', 
        setData: function (dataTransfer) {
          dataTransfer.setData('Text', '')
        },
        onEnd: evt => {
          const targetRow = this.tableData.splice(evt.oldIndex, 1)[0]
          this.tableData.splice(evt.newIndex, 0, targetRow)
          const tempIndex = this.newList.splice(evt.oldIndex, 1)[0]
          this.newList.splice(evt.newIndex, 0, tempIndex)
        }
      })
    }
  }
}
</script>

<style>
.sortable-ghost {
  opacity: 0.8;
  color: #fff !important;
  background: #b0c4de !important;
}
</style>

<style scoped>
.icon-star {
  margin-right: 2px;
}
.drag-handler {
  width: 20px;
  height: 20px;
  cursor: pointer;
}
.show-d {
  margin-top: 15px;
}
</style>

本文章转载自 https://blog.csdn.net/LFQP_/article/details/129041031
https://www.itxst.com/sortablejs/neuinffi.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
element ui 表格可以通过手指拖动来实现重新排序的功能。步骤如下: 1. 首先,需要找到表格的 DOM 元素,也就是要拖拽元素的父容器。可以通过以下代码找到表格的 tbody 元素: ```javascript const tbody = this.$refs.manufacturing.$el.querySelector(".el-table__body-wrapper > table > tbody"); ``` 这里的 `this.$refs.manufacturing` 是指引用的表格组件,通过 `$el` 属性获取到真实的 DOM 元素。 2. 接下来,需要使用 Sortable 库来创建可拖拽的效果。可以使用以下代码: ```javascript Sortable.create(tbody, { onEnd({ newIndex, oldIndex }) { const currRow = _this.form.manufacturing.splice(oldIndex, 1)[0]; _this.form.manufacturing.splice(newIndex, 0, currRow); }, }); ``` 在 `onEnd` 回调函数中,可以通过 `newIndex` 和 `oldIndex` 获取到拖拽的新位置和原位置。然后,可以使用数组的 `splice` 方法将当前从原位置删除,并插入到新位置。 这样,通过以上步骤,就可以实现在 element ui 表格中使用手指拖动进的重新排序了。 请注意,以上代码示例中的 `this.$refs.manufacturing` 和 `_this.form.manufacturing` 是示例代码,具体的引用和数据需要根据实际情况进修改。同时,还需要确保已经引入了 Sortable 库。 参考资料: element ui 表格动态显示空白bug 修复方法 template文件应用 row-key填写唯一标识 id="dragTable"是为了通过document找到该父容器 <span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Vue2+elementui表格实现拖拽功能](https://blog.csdn.net/weixin_45441470/article/details/128701619)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [element ui 表格动态显示空白bug 修复方法](https://download.csdn.net/download/weixin_38563176/12952759)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [【VUE】ElementUI实现表格拖拽功能及大图预览](https://blog.csdn.net/weixin_47375144/article/details/131301371)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值