优化芋道后台菜单管理卡顿问题element-plus版本

2024-09-01 13:20

本文主要是介绍优化芋道后台菜单管理卡顿问题element-plus版本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.原因分析

芋道后台菜单管理使用element-plus的table组件进行页面显示。因一次加载数据太多导致页面需全部进行渲染非常卡顿。

处理方案:1、修改页面数据只渲染父级。

2.dome源代码

    <el-tablev-if="refreshTable"v-loading="loading":data="list":default-expand-all="isExpandAll"row-key="id"lazy:load="load":tree-props="{ children: 'children', hasChildren: 'hasChildren' }"><el-table-column :show-overflow-tooltip="true" label="菜单名称" prop="name" width="250" /><el-table-column align="center" label="图标" prop="icon" width="100"><template #default="scope"><Icon :icon="scope.row.icon" /></template></el-table-column><el-table-column label="排序" prop="sort" width="60" /><el-table-column :show-overflow-tooltip="true" label="权限标识" prop="permission" /><el-table-column :show-overflow-tooltip="true" label="组件路径" prop="component" /><el-table-column :show-overflow-tooltip="true" label="组件名称" prop="componentName" /><el-table-column label="状态" prop="status" width="80"><template #default="scope"><dict-tag :type="DICT_TYPE.COMMON_STATUS" :value="scope.row.status" /></template></el-table-column><el-table-column align="center" label="操作"><template #default="scope"><el-buttonv-hasPermi="['system:menu:update']"linktype="primary"@click="openForm('update', scope.row.id)">修改</el-button><el-buttonv-hasPermi="['system:menu:create']"linktype="primary"@click="openForm('create', undefined, scope.row.id)">新增</el-button><el-buttonv-hasPermi="['system:menu:delete']"linktype="danger"@click="handleDelete(scope.row.id)">删除</el-button></template></el-table-column></el-table>

3.JS代码源代码

 

<script lang="ts" setup>
import { DICT_TYPE, getIntDictOptions } from '@/utils/dict'
import { handleTree} from '@/utils/tree'
import * as MenuApi from '@/api/system/menu'
import MenuForm from './MenuForm.vue'
import { CACHE_KEY, useCache } from '@/hooks/web/useCache'defineOptions({ name: 'SystemMenu' })const { wsCache } = useCache()
const { t } = useI18n() // 国际化
const message = useMessage() // 消息弹窗const loading = ref(true) // 列表的加载中
const list = ref<any>([]) // 列表的数据-只有父节点数据
const listTree = ref<any>([]) // 列表的数据-只有父节点数据
const listChildren=ref<any>([]) //处理children原数据
const queryParams = reactive({name: undefined,status: undefined
})
const queryFormRef = ref() // 搜索的表单
const isExpandAll = ref(false) // 是否展开,默认全部折叠
const refreshTable = ref(true) // 重新渲染表格状态
import { cloneDeep } from 'lodash-es'
/** 查询列表 */
const getList = async () => {loading.value = truetry {const data = await MenuApi.getMenuList(queryParams)listTree.value= handleTree(data)const tree=cloneDeep(listTree.value)tree.forEach((itme)=>{if(itme.children){itme.hasChildren=truedelete itme.children}})list.value=tree} finally {loading.value = false}}//加载子节点
const load = (row: any,_treeNode: any,resolve: (date: any[]) => void
) => {listChildren.value=[]getChildren(cloneDeep(listTree.value),row)let children = listChildren.valuesetTimeout(()=>{if(children){resolve(children)} },100)}//获取子节点数据
const getChildren=(arr,row)=>{arr.forEach(element => {if(row.id===element.parentId){listChildren.value.push(element)if(element.children?.length){element.hasChildren=truedelete element.children}}if(element.children?.length){getChildren(element.children,row)}});
}/** 搜索按钮操作 */
const handleQuery = () => {getList()
}/** 重置按钮操作 */
const resetQuery = () => {queryFormRef.value.resetFields()handleQuery()
}/** 添加/修改操作 */
const formRef = ref()
const openForm = (type: string, id?: number, parentId?: number) => {formRef.value.open(type, id, parentId)
}/** 展开/折叠操作 */
const toggleExpandAll = () => {refreshTable.value = falseisExpandAll.value = !isExpandAll.valuenextTick(() => {refreshTable.value = true})
}/** 刷新菜单缓存按钮操作 */
const refreshMenu = async () => {try {await message.confirm('即将更新缓存刷新浏览器!', '刷新菜单缓存')// 清空,从而触发刷新wsCache.delete(CACHE_KEY.USER)wsCache.delete(CACHE_KEY.ROLE_ROUTERS)// 刷新浏览器location.reload()} catch {}
}/** 删除按钮操作 */
const handleDelete = async (id: number) => {try {// 删除的二次确认await message.delConfirm()// 发起删除await MenuApi.deleteMenu(id)message.success(t('common.delSuccess'))// 刷新列表await getList()} catch {}
}/** 初始化 **/
onMounted(() => {getList()
})
</script>

4、主要修改源代码

1、:load="load" 和对数据:tree-props进行赖加载处理

 

这篇关于优化芋道后台菜单管理卡顿问题element-plus版本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127050

相关文章

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

MyBatis Plus 中 update_time 字段自动填充失效的原因分析及解决方案(最新整理)

《MyBatisPlus中update_time字段自动填充失效的原因分析及解决方案(最新整理)》在使用MyBatisPlus时,通常我们会在数据库表中设置create_time和update... 目录前言一、问题现象二、原因分析三、总结:常见原因与解决方法对照表四、推荐写法前言在使用 MyBATis

Mybatis Plus Join使用方法示例详解

《MybatisPlusJoin使用方法示例详解》:本文主要介绍MybatisPlusJoin使用方法示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录1、pom文件2、yaml配置文件3、分页插件4、示例代码:5、测试代码6、和PageHelper结合6

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Java死锁问题解决方案及示例详解

《Java死锁问题解决方案及示例详解》死锁是指两个或多个线程因争夺资源而相互等待,导致所有线程都无法继续执行的一种状态,本文给大家详细介绍了Java死锁问题解决方案详解及实践样例,需要的朋友可以参考下... 目录1、简述死锁的四个必要条件:2、死锁示例代码3、如何检测死锁?3.1 使用 jstack3.2

解决JSONField、JsonProperty不生效的问题

《解决JSONField、JsonProperty不生效的问题》:本文主要介绍解决JSONField、JsonProperty不生效的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录jsONField、JsonProperty不生效javascript问题排查总结JSONField

github打不开的问题分析及解决

《github打不开的问题分析及解决》:本文主要介绍github打不开的问题分析及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、找到github.com域名解析的ip地址二、找到github.global.ssl.fastly.net网址解析的ip地址三

MySQL版本问题导致项目无法启动问题的解决方案

《MySQL版本问题导致项目无法启动问题的解决方案》本文记录了一次因MySQL版本不一致导致项目启动失败的经历,详细解析了连接错误的原因,并提供了两种解决方案:调整连接字符串禁用SSL或统一MySQL... 目录本地项目启动报错报错原因:解决方案第一个:第二种:容器启动mysql的坑两种修改时区的方法:本地