在Vue项目中使用URL Query保存和恢复搜索条件的操作指南

 更新时间:2025年09月18日 10:28:39   作者:EMT  
在实际的前端开发中,我们经常会遇到这样的需求:用户在列表页输入了一些搜索条件,点击某一条数据进入详情页;当他返回列表页时,希望搜索条件能被 记住,而不是重新初始化,本文给大家介绍了Vue使用URL Query保存和恢复搜索条件的操作指南,需要的朋友可以参考下

引言

在实际的前端开发中,我们经常会遇到这样的需求:
用户在列表页输入了一些搜索条件,点击某一条数据进入详情页;当他返回列表页时,希望搜索条件能被 记住,而不是重新初始化。

常见的解决方案有三种:

  1. 使用 全局状态管理(Vuex/Pinia) 保存搜索条件。
  2. 使用 keep-alive 缓存页面组件。
  3. 使用 URL Query 参数 把搜索条件保存在地址栏中。

本文介绍的是第三种方式,通过封装一个 useQueryStorage Hook,把对象序列化到 URL 的 querystring 中,从而实现搜索条件的记忆。

核心代码

import { isEqual } from "lodash-es";
import { useRouter, useRoute } from "vue-router";

export const useQueryStorage = <T>(key: string = "savedQuery") => {
  const router = useRouter();
  const route = useRoute();

  // 把对象以 JSON 的格式存入到 URL 的 querystring 中
  const saveObjectToQueryString = (obj: T) => {
    const query = parseSavedObjectFromQueryString();
    if (!isEqual(query, obj)) {
      router.replace({
        query: {
          ...route.query,
          [key]: encodeURIComponent(JSON.stringify(obj)),
        },
      });
    }
  };

  // 从 URL 的 querystring 中解析出对象
  const parseSavedObjectFromQueryString: () => T | null = () => {
    let query = route.query[key];
    if (query && typeof query === "string") {
      query = JSON.parse(decodeURIComponent(query));
      return query as T;
    }
    return null;
  };

  return {
    getQ: parseSavedObjectFromQueryString,
    setQ: saveObjectToQueryString,
  };
};

代码解析

1. 存储对象到 URL

const saveObjectToQueryString = (obj: T) => {
  const query = parseSavedObjectFromQueryString();
  if (!isEqual(query, obj)) {
    router.replace({
      query: {
        ...route.query,
        [key]: encodeURIComponent(JSON.stringify(obj)),
      },
    });
  }
};

这里使用了 JSON.stringify 把对象转成字符串,再用 encodeURIComponent 确保字符串在 URL 中不会出错。

为什么要用 lodash.isEqual

因为 Vue Router 的 replace 会更新 URL,如果我们每次都写入同样的对象,就会产生冗余的路由更新。用 isEqual 做深度比较,可以避免不必要的刷新。

2. 从 URL 解析对象

const parseSavedObjectFromQueryString: () => T | null = () => {
  let query = route.query[key];
  if (query && typeof query === "string") {
    query = JSON.parse(decodeURIComponent(query));
    return query as T;
  }
  return null;
};

这一段逻辑就是把 querystring 里的值取出来,做 解码 + JSON 反序列化,还原成原来的对象。

3. Hook 的返回值

return {
  getQ: parseSavedObjectFromQueryString,
  setQ: saveObjectToQueryString,
};

对外提供两个方法:

  • getQ():获取保存的搜索条件。
  • setQ(obj):设置搜索条件并保存到 URL。

这样调用方的代码就会非常简洁。

使用示例

在列表页中:

const { getQ, setQ } = useQueryStorage<{ keyword: string; page: number }>();

// 初始化时恢复
const saved = getQ();
if (saved) {
  searchForm.keyword = saved.keyword;
  searchForm.page = saved.page;
}

// 用户点击搜索时保存
function handleSearch() {
  setQ({ keyword: searchForm.keyword, page: searchForm.page });
}

当用户进入详情页再返回时,URL 中依然保存了搜索条件,页面加载时会自动恢复。

优点总结

  1. 刷新不丢失
    因为状态存放在 URL 里,刷新后依然可以恢复。
  2. 可分享链接
    用户可以直接复制 URL,别人打开时能看到相同的搜索条件。
  3. 解耦全局状态
    不依赖 Vuex/Pinia,逻辑简单清晰。

缺点是:如果搜索条件非常复杂,URL 会变长,可能不太美观。

总结

useQueryStorage 是一个非常实用的小 Hook,通过 encodeURIComponentJSON.stringify 将对象持久化到 URL 的 query 参数中,结合 lodash.isEqual 避免重复写入,能很好地解决 列表页返回时记住搜索条件 的问题。

以上就是在Vue项目中使用URL Query保存和恢复搜索条件的操作指南的详细内容,更多关于Vue URL Query保存和恢复搜索条件的资料请关注脚本之家其它相关文章!

相关文章

  • vue第三方库中存在扩展运算符报错问题的解决方案

    vue第三方库中存在扩展运算符报错问题的解决方案

    这篇文章主要介绍了vue第三方库中存在扩展运算符报错问题,本文给大家分享解决方案,通过结合实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-07-07
  • Vue build过程取消console debugger控制台信息输出方法详解

    Vue build过程取消console debugger控制台信息输出方法详解

    这篇文章主要为大家介绍了Vue build过程取消console debugger控制台信息输出方法详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-09-09
  • 对 Vue-Router 进行单元测试的方法

    对 Vue-Router 进行单元测试的方法

    这篇文章主要介绍了对 Vue-Router 进行单元测试的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-11-11
  • vue中使用hover选择器无效的问题

    vue中使用hover选择器无效的问题

    这篇文章主要介绍了vue中使用hover选择器无效的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • vue中如何获取本地IP地址

    vue中如何获取本地IP地址

    这篇文章主要介绍了vue中如何获取本地IP地址,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • el-form组件清除校验提示正确方法(前端技能提升)

    el-form组件清除校验提示正确方法(前端技能提升)

    el-form组件提供了表单验证的功能,可以通过在el-form上绑定rules属性,并在el-form-item上设置prop属性来进行校验,这篇文章主要给大家介绍了关于el-form组件清除校验提示正确方法(前端技能提升)的相关资料,需要的朋友可以参考下
    2023-12-12
  • 在vue-cli项目中如何使用swiper

    在vue-cli项目中如何使用swiper

    这篇文章主要介绍了在vue-cli项目中如何使用swiper问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • vant-list上拉加载onload事件触发多次问题及解决

    vant-list上拉加载onload事件触发多次问题及解决

    这篇文章主要介绍了vant-list上拉加载onload事件触发多次问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-01-01
  • 浅谈vant组件Picker 选择器选单选问题

    浅谈vant组件Picker 选择器选单选问题

    这篇文章主要介绍了浅谈vant组件Picker 选择器选单选问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • Vue简易注册页面+发送验证码功能的实现示例

    Vue简易注册页面+发送验证码功能的实现示例

    本文主要介绍了Vue简易注册页面+发送验证码功能的实现示例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11

最新评论