场景2:Vue Router 中 query 与 params 的区别

在 Vue Router 中,query 和 params 都是我们常用的路由传参方式,对于他们的使用大家都不陌生,但在日常开发者有一些需要注意的点。

query 参数

  • 在路由配置中不需要声明
  • 刷新页面后参数继续存在(*重点*)
  • URL 格式:
javascript 复制代码
/path?query=value

示例:

javascript 复制代码
/user/list?page=2&keyword=vue
  • 跳转方式:
javascript 复制代码
router.push({
  path: '/user/list',
  query: {
    page: 2,
    keyword: 'vue'
  }
})
  • 接收方式:
javascript 复制代码
route.query.page
route.query.keyword

params 参数

  • 在路由配置中需要声明
  • 刷新页面后参数可能丢失(*重点*)
  • URL 格式:
javascript 复制代码
/path/:id

示例:

  • 路由配置:
javascript 复制代码
{
  path: '/user/:id',
  name: 'userDetail',
  component: UserDetail
}
  • 跳转方式:
javascript 复制代码
router.push({
  name: 'userDetail',
  params: { id: 15 }
})
  • 接收方式:
javascript 复制代码
route.params.id

在编写 params 参数跳转方式时,必须使用 name,而不能使用 path,比如:

javascript 复制代码
// 错误写法1
router.push({
  path: '/user',
  params: { id: 1 }
})

// 错误写法2
router.push({
  path: '/user/:id',
  params: { id: 1 }
})

// 正确写法
router.push({
  name: 'userDetail',
  params: { id: 1 }
})

为什么 params 在刷新页面后会丢失?

这取决于我们在路由配置时的声明方式:

  • 方法1:未定义占位符
javascript 复制代码
{ path: '/user', name: 'userDetail', component: xxx }
  • 方法2:定义占位符
javascript 复制代码
{ path: '/user/:id', name: 'userDetail', component: xxx }
  • 当我进行跳转时:
javascript 复制代码
router.push({ name: 'userDetail', params: { id: 1 } })
  • 方法1最终URL:
javascript 复制代码
/user/1
  • 方法2最终URL:
javascript 复制代码
/user

定义了占位符的方法2不会丢失 params,因为 :id 已经包含在 URL 中;

如果使用方法1,params 是存在于 路由对象内存中,URL 中没有 params,刷新页面后路由无法恢复之前的 params 从而导致丢失。

因此,params 是否丢失的关键在:是否写入 URL。我们可以使用 params + 占位符 的方式,也可以使用 query 方式。

相关推荐
淡忘_cx8 小时前
使用Jenkins自动化部署vue项目(2.528.2版本)
vue.js·自动化·jenkins
顾北128 小时前
AI对话应用接口开发全解析:同步接口+SSE流式+智能体+前端对接
前端·人工智能
iDao技术魔方9 小时前
深入Vue 3响应式系统:为什么嵌套对象修改后界面不更新?
javascript·vue.js·ecmascript
历程里程碑9 小时前
普通数组-----除了自身以外数组的乘积
大数据·javascript·python·算法·elasticsearch·搜索引擎·flask
摸鱼的春哥9 小时前
春哥的Agent通关秘籍07:5分钟实现文件归类助手【实战】
前端·javascript·后端
念念不忘 必有回响9 小时前
viepress:vue组件展示和源码功能
前端·javascript·vue.js
Amumu121389 小时前
Vue3 Composition API(一)
开发语言·javascript·ecmascript
C澒9 小时前
多场景多角色前端架构方案:基于页面协议化与模块标准化的通用能力沉淀
前端·架构·系统架构·前端框架
崔庆才丨静觅9 小时前
稳定好用的 ADSL 拨号代理,就这家了!
前端
江湖有缘9 小时前
Docker部署music-tag-web音乐标签编辑器
前端·docker·编辑器