场景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 方式。

相关推荐
码事漫谈2 小时前
当AI开始“思考”:我们是否真的准备好了?
前端·后端
许杰小刀2 小时前
ctfshow-web文件包含(web78-web86)
android·前端·android studio
我是Superman丶3 小时前
Element UI 表格某行突出悬浮效果
前端·javascript·vue.js
恋猫de小郭3 小时前
你的代理归我了:AI 大模型恶意中间人攻击,钱包都被转走了
前端·人工智能·ai编程
xiaokuangren_3 小时前
前端css颜色
前端·css
Huanzhi_Lin4 小时前
关于V8/MajorGC/MinorGC——性能优化
javascript·性能优化·ts·js·v8·新生代·老生代
hoiii1874 小时前
C# 基于 LumiSoft 实现 SIP 客户端方案
前端·c#
anOnion4 小时前
构建无障碍组件之Meter Pattern
前端·html·交互设计
小码哥_常4 小时前
Spring Boot配置diff:解锁配置管理新姿势
前端
小码哥_常5 小时前
告别onActivityResult!Android数据回传的3大痛点与终极解决方案
前端