当前位置: 首页 > article >正文

Vue(二十):ElementUI 扩展实现表格组件的拖拽行

效果

在这里插入图片描述

源码

注意: 表格组件必须添加 row-key 属性,用来优化表格的渲染

<template>
	<el-row :gutter="10">
		<el-col :span="12">
			<el-card class="card">
				<el-scrollbar>
					<span>注意: 表格组件必须添加 row-key 属性,用来优化表格的渲染</span>
					<pre>{{ JSON.stringify(tableData.map(d => JSON.stringify(d)), null, 4) }}</pre>
				</el-scrollbar>
			</el-card>
		</el-col>
		<el-col :span="12">
			<el-table ref="dragTableRef" style="width: 100%" :data="tableData" border stripe height="calc(100vh - 16px)" row-key="id">
				<el-table-column type="index" label="序号" width="60" align="center"/>
				<el-table-column prop="id" label="ID" align="center" width="100"/>
				<el-table-column prop="name" label="姓名" header-align="center"/>
				<el-table-column prop="email" label="邮箱" header-align="center"/>
				<el-table-column prop="address" label="地址" header-align="center"/>
			</el-table>
		</el-col>
	</el-row>
</template>

<script setup>
import {nextTick, reactive, ref} from "vue";
import Sortable from 'sortablejs';

const dragTableRef = ref(null);
const tableData = reactive([
	{id: '01', name: '西乐', email: 'XiLe@126.com', address: '安徽省宜都县普陀路304号'},
	{id: '02', name: '令玥傲', email: 'LingAo@126.com', address: '广东省六盘水县萧山街423号'},
	{id: '03', name: '爱宜豪', email: 'AiYiHao@126.com', address: '辽宁省六安县东城街448号'},
	{id: '04', name: '堵欣欣', email: 'DuXinXin@hotmail.com', address: '乌鲁木齐市高明街32号'},
	{id: '05', name: '楚文杰', email: 'ChuWenJie@qq.com', address: '四川省台北县吉区街375号'},
	{id: '06', name: '法晨茜', email: 'FaChenXi@126.com', address: '陕西省荆门县翔安路22号'},
	{id: '07', name: '凤萌', email: 'FengMeng@126.com', address: '台湾省台北县淄川街150号'},
	{id: '08', name: '驷尚', email: 'SiShang@hotmail.com', address: '山东省乌鲁木齐市清浦街48号'},
	{id: '09', name: '房紫轩', email: 'FangZiXuan@qq.com', address: '黑龙江省济南县永川路79号'},
	{id: '10', name: '丘伟洋', email: 'QiuWeiYang@gmail.com', address: '北京市拉萨市南长路245号'},
]);

nextTick(() => {
	const tableBodyWrapperEl = dragTableRef.value.$el.querySelector('.el-table__inner-wrapper .el-table__body-wrapper');
	const el = tableBodyWrapperEl.querySelector('.el-table__body tbody');
	const scrollEl = tableBodyWrapperEl.querySelector('.el-scrollbar .el-scrollbar__wrap');
	new Sortable(el, {
		// 被选中项样式选择器
		chosenClass: 'bg-green',
		// 基于某标签进行滚动
		scroll: scrollEl,
		// 结束拖拽
		onEnd: e => {
			console.log(`位置: form ${e.oldIndex} to ${e.newIndex}`);
			// 位置相同为无效移动
			if (e.oldIndex === e.newIndex) return;
			// 获取旧位置数据
			const [item] = tableData.splice(e.oldIndex, 1);
			// 移动到新位置
			tableData.splice(e.newIndex, 0, item);
		},
	});
});
</script>

<style scoped>
.card {
	height: calc(100vh - 16px);

	::v-global(.el-card__body) {
		height: calc(100% - 40px);

		span {
			color: red;
		}
	}
}
</style>

<style>
.bg-green td {
	background-color: green !important;
}
</style>

http://www.kler.cn/a/229691.html

相关文章:

  • vue3+vite图片动态地址问题 + nginx配置
  • 【计算机网络】lab3 802.11 (无线网络帧)
  • thinkphp6入门(17)-- 网站开发中session、cache、cookie的区别
  • 双非本科准备秋招(18.1)—— 力扣二叉树
  • nginx 的 ngx_http_upstream_dynamic_module 动态域名解析功能的使用和源码详解
  • 作业2024/2/5
  • Javaweb之SpringBootWeb案例之 登录功能的详细解析
  • 人工智能深度学习发展历程-纪年录
  • 来看看Tomcat和Web应用的目录结构
  • 数据分析基础之《pandas(5)—文件读取与存储》
  • GPT-1, GPT-2, GPT-3, GPT-3.5, GPT-4论文内容解读
  • [香橙派开发系列]使用蓝牙和手机进行信息的交换
  • Redis(十三)缓存双写一致性策略
  • 《【python】staticmethod与classmethod深度机制解析——要知其所以然》学习笔记
  • 十六、Vben框架table内部合并行
  • 88 SRC挖掘-拿下CNVD证书开源闭源售卖系统
  • 倒计时64天
  • 肯尼斯·里科《C和指针》第12章 使用结构和指针(1)链表
  • SpringBoot:配置相关知识点
  • nginx upstream server主动健康检测模块ngx_http_upstream_check_module 使用和源码分析(上)
  • pytorch的安装步骤
  • QT Linux下无法使用CTRL+ALT+P快捷键,不生效