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 --> :

相关推荐
Macbethad14 小时前
半导体EFEM设备TwinCAT程序设计方案
java·前端·网络
ggaofeng14 小时前
理解npm的原理
前端·npm·node.js
电商API_1800790524714 小时前
1688商品详情采集API全解析:技术原理、实操指南与业务落地
大数据·前端·人工智能·网络爬虫
記億揺晃着的那天14 小时前
Chrome 自动填充“用户名”到普通输入框 - 解决方案
前端·chrome
LawrenceLan14 小时前
Flutter 零基础入门(二十一):Container、Padding、Margin 与装饰
开发语言·前端·flutter·dart
967715 小时前
初始web server的认识1---webserver的用途和工作流程
前端
叫我:松哥15 小时前
基于神经网络算法的多模态内容分析系统,采用Flask + Bootstrap + ECharts + LSTM-CNN + 注意力机制
前端·神经网络·算法·机器学习·flask·bootstrap·echarts
vx_bisheyuange15 小时前
基于SpringBoot的知识竞赛系统
大数据·前端·人工智能·spring boot·毕业设计
搂着猫睡的小鱼鱼15 小时前
签名逆向与浏览器自动化 / 动态渲染抓取京东评论信息
前端·javascript·自动化
wangbing112515 小时前
ES6 (ES2015)新增的集合对象Set
前端·javascript·es6