Vue路由状态持久化方案,优雅实现记住表单历史搜索记录!

Vue路由状态持久化方案:优雅实现搜索条件记忆功能

背景痛点

在管理后台开发中,我们经常会遇到这样的场景:

  • 用户在搜索页面输入条件查询数据
  • 点击某条数据查看详情
  • 返回列表页时,之前的搜索条件全部丢失,需要重新输入

这种体验非常不友好!本文将介绍一种‌最小改动、最大复用的解决方案。

技术方案选型

需求分析

  1. 需要保存:搜索条件、分页参数、额外参数
  2. 需要控制:哪些页面/操作需要保存状态
  3. 实现要求:对现有代码改动最小

方案对比

方案 优点 缺点
Vuex持久化 全局状态管理 需要改造store结构
URL参数 天然共享 长度限制,安全性问题
LocalStorage 无需后端,容量大 需要手动清理

最终选择基于LocalStorageHooks封装方案。

核心实现方案:

采用hooks方法实现:

新建/mixins/storagePageConfig.js

代码如下:

ini 复制代码
export default {
    data() {
        return {
            isPageFlag: false
        }
    },
    //进入页面
    beforeRouteEnter(to, from, next) {
        next((vm) => {
            let routePage = localStorage.getItem("routePage");
            if (routePage) {
                let routePageObj = JSON.parse(routePage) || {};
                if (routePageObj[vm.$route.path]?.page) {
                    vm.page.pageNum = routePageObj[vm.$route.path]?.page?.pageNum || 1;
                    vm.page.pageSize = routePageObj[vm.$route.path]?.page?.pageSize || 10;
                }
                if (routePageObj[vm.$route.path]?.queryParams) {
                    vm.queryParams = routePageObj[vm.$route.path]?.queryParams || {};
                }
                if (routePageObj[vm.$route.path]?.paramList) {
                    vm.paramList = routePageObj[vm.$route.path]?.paramList || [];
                }
            }
            vm.getList();
        });
    },
    //离开页面路由拦截
    beforeRouteLeave(to, from, next) {
        let routePage = localStorage.getItem("routePage");
        let routePageObj = {};
        if (routePage) routePageObj = JSON.parse(routePage) || {};
        if (this.isPageFlag === true) {
            routePageObj[this.$route.path] = {
                page: this.page,
                queryParams: this.queryParams,
                paramList: this.paramList,
            };
            localStorage.setItem("routePage", JSON.stringify(routePageObj));
        } else {
            routePageObj[this.$route.path] = {};
            localStorage.setItem("routePage", JSON.stringify(routePageObj));
        }
        next();
    },
}

解析:

  1. data部分‌:
  • 定义了isPageFlag布尔值变量,用于标记是否需要保存页面状态‌。
  1. beforeRouteEnter导航守卫‌:
  • 在进入路由前执行,通过localStorage读取之前保存的页面状态数据‌
  • 如果存在保存的状态,则恢复分页参数(pageNum/pageSize)、查询参数(queryParams)和参数列表(paramList)到当前组件实例‌
  • 最后调用getList()方法加载数据‌
  1. beforeRouteLeave导航守卫‌:
  • 在离开路由前执行,根据isPageFlag决定是否保存当前页面状态到localStorage
  • 如果isPageFlag为true,则保存分页参数、查询参数和参数列表‌
  • 否则清空该路由路径下的保存数据‌
  • 最后调用next()继续导航流程‌

使用:

点击跳转时需要记录,将isPageFlag变量状态变更为true --> :

相关推荐
YGY Webgis糕手之路2 小时前
OpenLayers 综合案例-轨迹回放
前端·经验分享·笔记·vue·web
90后的晨仔3 小时前
🚨XSS 攻击全解:什么是跨站脚本攻击?前端如何防御?
前端·vue.js
Ares-Wang3 小时前
JavaScript》》JS》 Var、Let、Const 大总结
开发语言·前端·javascript
90后的晨仔3 小时前
Vue 模板语法完全指南:从插值表达式到动态指令,彻底搞懂 Vue 模板语言
前端·vue.js
德育处主任3 小时前
p5.js 正方形square的基础用法
前端·数据可视化·canvas
烛阴3 小时前
Mix - Bilinear Interpolation
前端·webgl
90后的晨仔3 小时前
Vue 3 应用实例详解:从 createApp 到 mount,你真正掌握了吗?
前端·vue.js
德育处主任3 小时前
p5.js 矩形rect绘制教程
前端·数据可视化·canvas
前端工作日常4 小时前
我学习到的babel插件移除Flow 类型注解效果
前端·babel·前端工程化
SY_FC4 小时前
uniapp input 聚焦时键盘弹起滚动到对应的部分
javascript·vue.js·elementui