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

Vue中实现动态标签页的切换优化与状态管理

1. 动态标签页的核心需求与实现思路在后台管理系统这类多页面应用中动态标签页几乎是标配功能。想象一下你正在使用某电商后台同时开着商品管理、订单处理和用户分析三个页面这时候标签页的流畅切换和状态保持就显得尤为重要。我经历过一个真实项目用户抱怨每次刷新页面标签页就消失或者关闭某个标签后跳转逻辑混乱。这就是典型的状态管理问题。Vue生态中VuexsessionStorage的组合拳能完美解决这个问题Vuex负责运行时状态管理当前激活页、标签列表等sessionStorage保证页面刷新时数据不丢失路由守卫处理标签关闭时的页面跳转逻辑实测下来这套方案在中小型项目中非常稳定。下面这段代码是状态管理的核心骨架// store.js 基础配置 export default new Vuex.Store({ state: { tabList: [{ path: /dashboard, label: 控制台 }], // 标签页集合 activeTab: /dashboard // 当前激活页 }, mutations: { addTab(state, newTab) { if (!state.tabList.some(tab tab.path newTab.path)) { state.tabList.push(newTab) } state.activeTab newTab.path } } })2. 状态持久化实战方案2.1 Vuex与sessionStorage的协同工作页面刷新时Vuex状态会重置这是前端常识。但用户可不知道这些他们只觉得我的标签页怎么没了。这时候就需要sessionStorage来救场存储时机在Vuex mutation中同步更新sessionStorage读取时机在应用初始化时从sessionStorage恢复数据清理时机浏览器关闭时自动清空sessionStorage特性这里有个坑我踩过直接存储对象会导致序列化问题。正确做法是// 在store.js中添加插件 const syncToStorage store { store.subscribe((mutation, state) { // 只持久化特定数据 sessionStorage.setItem(tabState, JSON.stringify({ tabList: state.tabList, activeTab: state.activeTab })) }) } // 初始化时恢复数据 const savedState sessionStorage.getItem(tabState) const initialState savedState ? JSON.parse(savedState) : {} export default new Vuex.Store({ state: { tabList: initialState.tabList || [{ path: /, label: 首页 }], activeTab: initialState.activeTab || / }, plugins: [syncToStorage] })2.2 KeepAlive缓存页面状态光有标签页不够页面内容也需要缓存。Vue的keep-alive组件配合动态路由简直完美template keep-alive :includecachedPages router-view :key$route.fullPath/ /keep-alive /template script export default { computed: { cachedPages() { return this.$store.state.cachedComponents } } } /script在Vuex中维护需要缓存的组件名列表通过路由钩子动态更新// 路由配置中添加meta信息 { path: /user, component: UserManage, meta: { keepAlive: true } } // 全局路由守卫 router.beforeEach((to, from, next) { if (to.meta.keepAlive) { store.commit(addCache, to.name) } next() })3. 标签页交互优化技巧3.1 智能关闭逻辑设计关闭标签页时的跳转逻辑是用户体验的关键。根据Ant Design等主流方案最佳实践是关闭当前页时如果右侧有标签激活右侧标签如果左侧有标签激活左侧标签如果是最后一个标签回到首页handleClose(tab, index) { const { tabList } this.$store.state const nextTab tabList[index 1] || tabList[index - 1] this.$store.commit(removeTab, tab.path) if (tab.path this.$route.path) { this.$router.push(nextTab ? nextTab.path : /) } }3.2 滚动导航解决方案当标签页超出可视区域时通常有两种处理方案滚动条方案类似Chrome标签页的横向滚动折叠菜单方案超出部分显示下拉菜单我推荐第一种方案实现起来更直观。关键是要计算标签容器的宽度和位移updateScrollPosition() { const $container this.$refs.tabsContainer const $activeTab this.$refs.activeTab if (!$container || !$activeTab) return const containerWidth $container.offsetWidth const tabOffset $activeTab.offsetLeft const tabWidth $activeTab.offsetWidth // 计算需要的滚动位置 let scrollPosition tabOffset - (containerWidth - tabWidth) / 2 scrollPosition Math.max(0, scrollPosition) this.scrollLeft scrollPosition }在模板中使用transform实现平滑滚动div classtabs-container reftabsContainer div classtabs-wrapper :style{ transform: translateX(-${scrollLeft}px) } !-- 标签页内容 -- /div /div4. 性能优化与边界情况处理4.1 内存管理策略长时间运行的SPA容易内存泄漏特别是在使用keep-alive时。我们需要限制缓存页面数量建议不超过10个在路由离开时清理不需要的缓存// 在全局混入中加入清理逻辑 Vue.mixin({ beforeRouteLeave(to, from, next) { if (!to.meta.keepAlive) { this.$store.commit(removeCache, from.name) } next() } })4.2 多标签页通信方案当多个标签页需要状态同步时可以考虑BroadcastChannel API现代浏览器支持localStorage事件兼容性更好// 使用BroadcastChannel同步状态 const channel new BroadcastChannel(tab_sync) channel.addEventListener(message, event { if (event.data.type TAB_UPDATE) { this.$store.commit(updateTabs, event.data.payload) } }) // 在Vuex mutation中发送更新 function sendUpdate(state, payload) { channel.postMessage({ type: TAB_UPDATE, payload }) }5. 移动端适配方案在移动设备上标签页需要特殊的交互设计手势滑动切换监听touch事件下拉关闭类似微信小程序紧凑布局缩小标签间距实现手势滑动的核心代码handleTouchStart(e) { this.startX e.touches[0].clientX } handleTouchMove(e) { if (!this.startX) return const deltaX e.touches[0].clientX - this.startX if (Math.abs(deltaX) 50) { const direction deltaX 0 ? prev : next this.switchTab(direction) this.startX null } } switchTab(direction) { const currentIndex this.tabList.findIndex(tab tab.active) const targetIndex direction prev ? currentIndex - 1 : currentIndex 1 if (targetIndex 0 targetIndex this.tabList.length) { this.$router.push(this.tabList[targetIndex].path) } }在项目中实际使用时建议配合vue-touch这类手势库能省去不少边界情况处理的麻烦。

相关文章:

Vue中实现动态标签页的切换优化与状态管理

1. 动态标签页的核心需求与实现思路 在后台管理系统这类多页面应用中,动态标签页几乎是标配功能。想象一下你正在使用某电商后台,同时开着商品管理、订单处理和用户分析三个页面,这时候标签页的流畅切换和状态保持就显得尤为重要。 我经历过一…...

基于LSTM的短期电力负荷预测研究

【负荷预测】基于LSTM短期负荷预测,可考虑需求响应 短期电力负荷预测在电力系统的调度、生产和规划中起着重要的作用,精准的负荷预测有利于决策者做出正确决策计划以及有利于电力系统的稳定运行。 多个售电主体的市场竞争带来了电价的波动,以…...

图床项目(二) 接口设计

接口设计 1 . muduo 网络模型 该模型相较于普通的reactor模型复杂一点,其中包括mainReactor 和 多个 subReactor ,其中每一个 subReactor对应一个线程。 其中 mainReactor 负责处理新连接 , 并将连接均匀分配给 subReactor ,后续…...

COA - CNN - BiGRU - Attention分类:新手友好的数据预测方案

COA-CNN-BiGRU-Attention分类 基于浣熊优化算法优化卷积神经网络(CNN)-双向门控循环单元(BGRU)结合注意力机制(Attention)的数据分类预测(可更换为回归/单变量/多变量时序预测,前私),Matlab代码,可直接运行,适合小白新手 无需更改…...

N诺机试题

2.整除&#xff08;末尾无空格用printf“ ”&#xff09;#include<stdio.h>int main(){int count0;for(int i100;i<1000;i){if(i%50&&i%60){printf("%d",i);count;if(count%100) printf("\n");else printf(" "); }}return 0;…...

手把手教你用4G Cat.1 bis开发智能硬件:从电路设计到低功耗优化的完整实战

4G Cat.1 bis智能硬件开发实战&#xff1a;从电路设计到低功耗优化的全流程指南 在共享充电宝扫码即用的便利背后&#xff0c;隐藏着一场关于低功耗通信的技术革命。当传统4G模块因高功耗让硬件开发者束手无策时&#xff0c;4G Cat.1 bis以单天线设计、10Mbps传输速率和μA级待…...

Babel polyfill配置全解析:为什么你的Next.js项目在IE11还是报错?

Babel polyfill配置全解析&#xff1a;为什么你的Next.js项目在IE11还是报错&#xff1f; 在2023年的前端生态中&#xff0c;浏览器兼容性依然是个令人头疼的问题。最近接手一个企业级Next.js项目时&#xff0c;我遇到了一个典型场景&#xff1a;开发环境一切正常&#xff0c;但…...

突破信息获取壁垒:智能内容解锁工具使用指南

突破信息获取壁垒&#xff1a;智能内容解锁工具使用指南 【免费下载链接】bypass-paywalls-chrome-clean 项目地址: https://gitcode.com/GitHub_Trending/by/bypass-paywalls-chrome-clean 你是否曾遇到这样的情况&#xff1a;一篇专业的技术文章、一份重要的研究报告…...

SEO_2024年最新SEO趋势与核心优化方法介绍

<h1 id"seo2024seo">SEO:2024年最新SEO趋势与核心优化方法介绍</h1> <p>在互联网时代&#xff0c;搜索引擎优化&#xff08;SEO&#xff09;仍然是网站流量和品牌推广的关键。2024年&#xff0c;SEO领域有许多新的趋势和核心优化方法&#xff0c;帮…...

终极ThinkPad风扇控制指南:如何让你的笔记本更安静更高效?

终极ThinkPad风扇控制指南&#xff1a;如何让你的笔记本更安静更高效&#xff1f; 【免费下载链接】TPFanCtrl2 ThinkPad Fan Control 2 (Dual Fan) for Windows 10 and 11 项目地址: https://gitcode.com/gh_mirrors/tp/TPFanCtrl2 你是否曾经被ThinkPad风扇的噪音困扰…...

CnDataSeed发布:中国科研工作者跳槽研究数据库(CAMRD)

一、数据简介 追踪学术流动&#xff0c;解析科研人才动力机制&#xff01; 在中国科研生态快速演化的背景下&#xff0c;科研人才流动是科研创新与学术产出的关键驱动力。但跳槽相关研究在高教研究中一直较为稀缺&#xff0c;系统化、可量化的科研工作者跳槽数据长期缺失&…...

MATLAB中扩展卡尔曼滤波与无迹卡尔曼滤波源代码:一键运行,误差对比及显示最大误差数字图像程...

MATLAB编写的EKF和UKF滤波程序源代码 扩展卡尔曼滤波、无迹卡尔曼滤波的MATLAB程序&#xff0c;有误差对比图像和最大误差数字的显示。 只有一个m文件&#xff0c;打开就能运行。 带中文注释。直接双击EKFUKFComparison.m就能看到两个滤波器在非线性系统里的较量。这个文件里塞…...

从EWA Splatting到3DGS:一阶泰勒展开如何保住高斯的“椭圆”形状?

从EWA Splatting到3DGS&#xff1a;一阶泰勒展开如何保住高斯的“椭圆”形状&#xff1f; 在计算机图形学的演进历程中&#xff0c;三维高斯分布&#xff08;3D Gaussian&#xff09;的投影问题一直是个既基础又关键的挑战。想象一下&#xff0c;当你试图将一个完美的三维椭球投…...

三相不平衡电压下H桥五电平并网逆变器并网控制探究

三相不平衡电压下级连H桥五电平并网逆变器并网控制&#xff0c;SPWM调制&#xff0c;正负序分离控制 1.采用正负序分离锁相环以及正序PI控制&#xff0c;负序PI控制 2.采用中点电位平衡控制-零序电压注入法 3.提供参考文献 提供仿真源文件&#xff0c;电流环参数设计&#xff0…...

浙政钉应用监控埋点参数(bid, sapp_id)到底去哪找?一份给开发者的沟通指南

浙政钉应用监控埋点参数获取实战指南&#xff1a;从沟通到落地的全流程解析 在政务数字化进程中&#xff0c;浙政钉作为重要的政务协同平台&#xff0c;其应用监控埋点数据的准确采集直接影响着后续的数据分析和决策支持。然而&#xff0c;许多开发团队在实际项目中常常陷入参数…...

DeepSeek LintCode 3867 · 范围内的数字计数 public int digitsCount(int d, int low, int high)

LintCode 3867 范围内的数字计数 问题分析 计算在区间 [low, high] 中&#xff0c;数字 d 出现的次数。 核心思想&#xff1a;使用数位DP或前缀和思想 • count(low, high) count(0, high) - count(0, low-1) 方法一&#xff1a;逐位统计法&#xff08;推荐&#xff09;AC pu…...

保姆级教程:用 Modelfile 快速部署 ModelScope 的 GGUF 模型到 Ollama(以 DeepSeek 为例)

从零到一&#xff1a;用Modelfile高效部署ModelScope的GGUF模型至Ollama实战指南 在本地运行大语言模型正成为开发者探索AI边界的新常态。不同于直接调用云端API&#xff0c;本地部署能带来数据隐私保障、响应速度提升以及模型深度定制等独特优势。Ollama作为轻量级模型运行框架…...

MMSegmentation项目交付必备:如何生成让客户/导师眼前一亮的可视化报告(附完整脚本)

MMSegmentation项目交付必备&#xff1a;如何生成让客户/导师眼前一亮的可视化报告&#xff08;附完整脚本&#xff09; 在计算机视觉项目的最终交付环节&#xff0c;一份专业、直观的可视化报告往往比堆砌技术参数更能打动客户或导师。MMSegmentation作为开源图像分割领域的标…...

Ubuntu 24.04 环境实战:ROS 2 Kilted 实现 SLAM 建图与 Nav2 导航

一、构建地图 1、安装依赖 安装 slam_toolbox 算法库&#xff1a; sudo apt install ros-kilted-slam-toolbox安装 TurtleBot3 全套支持包&#xff1a; sudo apt install ros-kilted-turtlebot3*2、使用清华源 如果apt安装很慢&#xff0c;请先配置清华源&#xff1a; sud…...

vs code 实现source insight中的快捷键功能

1.自定义快捷键连续两组快捷键CtrlK CtrlS打开键盘快捷键定义界面修改向前向后的快捷键。ctrlu删除当前行复制当前行到下面2.增加bookmarks功能扩展部分装插件&#xff0c;定义快捷键ctrlm增加标签可以修改标签3.多行移动多行向上移动&#xff0c;向下移动Windows/Linux 用 Alt…...

CentOS7-IP配置记录

简要说明 本文章主要记录CentOS7系统在桥接网络类型下的IP配置测试&#xff0c;主要分为静态和动态配置&#xff0c;以下部署配置仅作参考&#xff0c;可根据实际情况调整。 相关文章 CentOS7部署参考文章&#xff1a;VMware-CentOS7最小化安装记录 CentOS7指令参考文章&am…...

Android16进阶之MediaPlayer.selectTrack调用流程与实战(二百五十)

简介&#xff1a; CSDN博客专家、《Android系统多媒体进阶实战》作者 博主新书推荐&#xff1a;《Android系统多媒体进阶实战》&#x1f680; Android Audio工程师专栏地址&#xff1a; Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; Android多媒体专栏地址&a…...

开源项目主题系统的3大核心机制深度解析:从CSS变量到动态切换的完整实现方案

开源项目主题系统的3大核心机制深度解析&#xff1a;从CSS变量到动态切换的完整实现方案 【免费下载链接】vue-vben-admin vbenjs/vue-vben-admin: 是一个基于 Vue.js 和 Element UI 的后台管理系统&#xff0c;支持多种数据源和插件扩展。该项目提供了一个完整的后台管理系统&…...

ESFT-gate-law-lite:法律文本智能分析新工具

ESFT-gate-law-lite&#xff1a;法律文本智能分析新工具 【免费下载链接】ESFT-gate-law-lite ESFT-gate-law-lite是基于HuggingFace的深度学习模型&#xff0c;专为法律领域定制。源自deepseek-ai团队&#xff0c;继承ESFT-vanilla-lite优势&#xff0c;强大而轻量&#xff0c…...

Ollama + DeepSeek + 芋道框架 + SearXNG 本地联网搜索完整教程

1. 环境准备与检查 在开始之前,请确保你的环境满足以下条件: 1.1 硬件要求 内存:建议至少8GB可用内存(运行7B模型需要约4-6GB) 硬盘:DeepSeek模型文件约4-5GB空间 CPU/GPU:如有NVIDIA GPU可加速推理(可选) 1.2 软件要求 操作系统:Windows 10/11、macOS、Linux均可 …...

首款支持AI渗透的WebShell管理工具,聊个天就能实现免杀|实现高隐蔽内网渗透

0x01 工具介绍 金刚狼首款支持 AI 渗透的 WebShell MCP&#xff0c;也是一款支持多层内网级联的 ASPX、ASHX 高级 WebShell 管理工具。工具采用 AES 加密通信&#xff0c;无需代理即可实现内网穿透&#xff0c;支持内存加载各类渗透工具&#xff0c;做到无文件落地隐蔽渗透目标…...

突破限制:BlenderCompat让Windows 7焕发新活力运行Blender 3.x

突破限制&#xff1a;BlenderCompat让Windows 7焕发新活力运行Blender 3.x 【免费下载链接】BlenderCompat Windows 7 support for Blender 3.x and newer 项目地址: https://gitcode.com/gh_mirrors/bl/BlenderCompat 在3D创作领域&#xff0c;Blender的每一次版本迭代…...

带标注的交通工具分类数据集,17334张原始图片,识别率92.4%,可识别汽车,公共汽车,自行车,摩托车,支持yolo,coco json,pascal voc xml格式

带标注的交通工具分类数据集&#xff0c;17334张原始图片&#xff0c;识别率92.4%&#xff0c;可识别汽车&#xff0c;公共汽车&#xff0c;自行车&#xff0c;摩托车&#xff0c;支持yolo&#xff0c;coco json&#xff0c;pascal voc xml格式 模型训练指标参数&#xff1a; …...

语音转换完全上手:Retrieval-based Voice-Conversion-WebUI从入门到精通

语音转换完全上手&#xff1a;Retrieval-based Voice-Conversion-WebUI从入门到精通 【免费下载链接】Retrieval-based-Voice-Conversion-WebUI 语音数据小于等于10分钟也可以用来训练一个优秀的变声模型&#xff01; 项目地址: https://gitcode.com/GitHub_Trending/re/Retr…...

日语零基础每天学习笔记【01-10】

第一天 日语五十音&#xff1a;平假名/片假名发音あア いイ うウ えエ おオaかカ きキ くク けケ こコkaさサ しシ すス せセ そソsaたタ ちチ つツ てテ とトtaなナ にニ ぬヌ ねネ のノnaはハ ひヒ ふフ へヘ ほホhaまマ みミ むム めメ もモmaや…...