IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> vue3+element+sortablejs实现table动态拖拽 -> 正文阅读

[JavaScript知识库]vue3+element+sortablejs实现table动态拖拽

最近项目迁移vue3+ts+vite+element-plus有一个拖拽的小需求接下来给大家操作一下

一、第一步我们要安装sortablejs依赖

npm install sortablejs --save

或者

yarn add sortablejs --save

二、在我们需要的组件中引入

import Sortable from 'sortablejs'

三、到这里就可以写我们的功能代码了

<template>
	<div class="app-container">
		<el-table class="tableContent" row-key="id" border :data="list" style="width: 100%">
			<el-table-column label="ID" prop="id" width="70px" align="center" />
			<el-table-column label="用户名称" prop="username" width="120px" align="center" />
			<el-table-column label="真实姓名" prop="name" width="120px" align="center" />
			<el-table-column label="所属部门" prop="deptName" align="center" />
			<el-table-column label="邮箱" prop="email" width="150px" align="center" />
			<el-table-column label="手机号" prop="mobile" width="150px" align="center" />
			<el-table-column label="状态" prop="statusDescribe" width="100px" align="center">
				<template #default="{ row }">
					<el-tag size="small" :type="row.status === 0 ? 'danger' : ''">{{ row.statusDescribe }}</el-tag>
				</template>
			</el-table-column>
			<el-table-column label="创建时间" prop="createdAt" width="160px" align="center" />
			<el-table-column label="操作" align="center" fixed="right" width="150px">
				<template #default="{ row }">
					<el-button v-permission="['sys:user:update']" type="primary" icon="edit" @click="handleUpdate(row)" />
					<el-button v-permission="['sys:user:delete']" type="danger" icon="delete" @click="handleDelete(row)" />
				</template>
			</el-table-column>
		</el-table>
	</div>
</template>

哥们儿 哥们儿 敲黑板了!!! 这里我们要注意的是 el-tablerow-id属性这个必需要添加否则无法拖拽

<script lang="ts">
	import {
		ref,
		toRefs,
		onMounted,
		reactive,
		defineComponent
	} from 'vue'
	// 拖拽插件
	import Sortable from 'sortablejs'
	import {
		getList
	} from '@/api/system/user'



	export default defineComponent({
		name: 'User',
		components: {},
		setup() {
			const state = reactive({
				list: [],
				total: 0,
				listQuery: {
					pageNo: 1,
					pageSize: 10,
					orderByField: 'createdAt',
					orderBy: 'desc'
				}
			})
			// methods
			const getData = async () => {
				try {
					const data = await getList(state.listQuery)
					state.list = data.list
				} catch (error: any) {
					throw new Error(error)
				}
			}
			// 创建拖拽实例
			const initSort = (className: string) => {
				const table = document.querySelector(`.${  className  } .el-table__body-wrapper tbody`);
				Sortable.create(table, {
					group: 'shared',
					animation: 150,
					easing: 'cubic-bezier(1, 0, 0, 1)',
					onStart: () => {
						console.log("开始拖动");
					},
					// 结束拖动事件
					onEnd: ({
						newIndex,
						oldIndex
					}: any) => {
						console.log(`拖动前索引${oldIndex}---拖动后索引${newIndex}`, "结束拖动");
						setNodeSort(state.list,oldIndex,newIndex)
					},
				})
			}
			// 拖拽完成修改数据排序
			const setNodeSort = (data:any, oldIndex:any, newIndex:any) => {
				const currRow = data.splice(oldIndex, 1)[0];
				data.splice(newIndex, 0, currRow);
			}
			onMounted(() => {
				getData()
				initSort('tableContent')
			})
			return {
				...toRefs(state),
				onMounted,
				getData,
				initSort,
				setNodeSort
			}
		}
	})

</script>

以上就完成了一个简单的table的拖拽功能,功能很简单,代码也不复杂,希望对大家能有所帮助,那么最后兄弟姐妹萌,点赞收藏关注,一键三连走一走,蟹蟹兄弟姐妹萌。

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-07-17 16:13:50  更:2022-07-17 16:17:55 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 12:56:51-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码