Vue Router 中 params 和 query 的区别

在 Vue Router 中,paramsquery 是两种不同的传递参数的方式,它们有以下主要区别:

1. 定义方式不同

params

  • 需要在路由路径中定义参数名
  • 适合传递必要参数(如ID)

javascript

复制

arduino 复制代码
// 路由配置
{
  path: '/user/:id',
  name: 'user',
  component: User
}

query

  • 不需要在路由路径中定义
  • 适合传递可选参数(如搜索条件)

javascript

复制

arduino 复制代码
// 路由配置
{
  path: '/search',
  name: 'search',
  component: Search
}

2. URL 表现形式不同

params

  • 参数是路径的一部分
  • 示例URL: /user/123
  • 不显示参数名

query

  • 参数在问号后以键值对形式出现
  • 示例URL: /search?name=john&age=25
  • 显示参数名和值

3. 使用方法不同

传递 params

javascript

复制

php 复制代码
// 编程式导航
router.push({ name: 'user', params: { id: 123 } })

// 声明式导航
<router-link :to="{ name: 'user', params: { id: 123 }}">用户</router-link>

传递 query

javascript

复制

php 复制代码
// 编程式导航
router.push({ path: '/search', query: { name: 'john', age: 25 } })

// 声明式导航
<router-link :to="{ path: '/search', query: { name: 'john', age: 25 }}">搜索</router-link>

4. 获取方式不同

获取 params

javascript

复制

csharp 复制代码
// 在组件中
this.$route.params.id
// 组合式API
import { useRoute } from 'vue-router'
const route = useRoute()
const id = route.params.id

获取 query

javascript

复制

kotlin 复制代码
// 在组件中
this.$route.query.name
// 组合式API
const name = route.query.name

5. 其他重要区别

特性 params query
是否必须定义 是(在路由配置中)
刷新后 可能丢失(除非使用命名路由) 保留
SEO影响 较小(看起来像静态路径) 较大(可能被搜索引擎索引)
参数可见性 隐藏 明文显示
长度限制 受URL总长度限制 受URL总长度限制

使用场景建议

  • 使用 params 当

    • 参数是资源标识(如用户ID)
    • 参数是必需的
    • 希望URL更简洁
  • 使用 query 当

    • 参数是可选的(如分页、筛选条件)
    • 需要分享带参数的URL
    • 参数需要被搜索引擎抓取

注意事项

  1. 使用 params 时,如果使用 path 而不是 name 进行导航,params 会被忽略:

    javascript

    复制

    php 复制代码
    // 这样不会工作
    router.push({ path: '/user', params: { id: 123 } })
    
    // 这样才有效
    router.push({ name: 'user', params: { id: 123 } })
  2. 在 Vue Router 4.x 中,如果没有在路由中定义 params 参数,它们将不会被添加到 URL 中。

  3. query 参数总是字符串类型,如果需要其他类型需要手动转换。

相关推荐
懒羊羊我小弟18 分钟前
使用 ECharts GL 实现交互式 3D 饼图:技术解析与实践
前端·vue.js·3d·前端框架·echarts
前端小巷子18 分钟前
CSS3 遮罩
前端·css·面试·css3
运维@小兵23 分钟前
vue访问后端接口,实现用户注册
前端·javascript·vue.js
雨汨26 分钟前
web:InfiniteScroll 无限滚动
前端·javascript·vue.js
Samuel-Gyx1 小时前
前端 CSS 样式书写与选择器 基础知识
前端·css
天天打码2 小时前
Rspack:字节跳动自研 Web 构建工具-基于 Rust打造高性能前端工具链
开发语言·前端·javascript·rust·开源
字节高级特工2 小时前
【C++】”如虎添翼“:模板初阶
java·c语言·前端·javascript·c++·学习·算法
db_lnn_20212 小时前
【vue】全局组件及组件模块抽离
前端·javascript·vue.js
Qin_jiangshan3 小时前
vue实现进度条带指针
前端·javascript·vue.js
菜鸟una3 小时前
【layout组件 与 路由镶嵌】vue3 后台管理系统
前端·vue.js·elementui·typescript