Vue Router:查询参数与动态路由参数示例

Vue Router:查询参数与动态路由参数示例

下面我用 Vue Router 为例,给你写一个完整的示例,分别演示查询参数传参动态路由传参的用法。


1. 路由配置(router/index.js)

JavaScript 复制代码
import Vue from 'vue'
import VueRouter from 'vue-router'
import QueryPage from '../views/QueryPage.vue'
import ParamsPage from '../views/ParamsPage.vue'

Vue.use(VueRouter)

const routes = [
  // 查询参数传参示例页
  {
    path: '/query',
    name: 'Query',
    component: QueryPage
  },
  // 动态路由传参示例页
  {
    path: '/params/:id', // 动态路由配置
    name: 'Params',
    component: ParamsPage
  }
]

const router = new VueRouter({
  routes
})

export default router

2. 查询参数传参示例

跳转页面(Home.vue)
Plain 复制代码
<template>
  <div>
    <h2>查询参数传参</h2>
    <button @click="goWithQuery">跳转到查询页(传多个参数)</button>
  </div>
</template>

<script>
export default {
  methods: {
    goWithQuery() {
      // 方式1:字符串拼接
      this.$router.push('/query?name=张三&age=25&city=北京')
      
      // 方式2:对象写法(推荐)
      // this.$router.push({
      //   path: '/query',
      //   query: {
      //     name: '张三',
      //     age: '25',
      //     city: '北京'
      //   }
      // })
    }
  }
}
</script>
接收参数页面(QueryPage.vue)
Plain 复制代码
<template>
  <div>
    <h2>查询参数接收页</h2>
    <p>姓名:{{ $route.query.name }}</p>
    <p>年龄:{{ $route.query.age }}</p>
    <p>城市:{{ $route.query.city }}</p>
  </div>
</template>

<script>
export default {
  mounted() {
    console.log(this.$route.query) // { name: '张三', age: '25', city: '北京' }
  }
}
</script>

3. 动态路由传参示例

跳转页面(Home.vue)
Plain 复制代码
<template>
  <div>
    <h2>动态路由传参</h2>
    <button @click="goWithParams">跳转到动态路由页(传单个ID)</button>
  </div>
</template>

<script>
export default {
  methods: {
    goWithParams() {
      // 方式1:字符串拼接
      this.$router.push('/params/123')
      
      // 方式2:命名路由(推荐)
      // this.$router.push({
      //   name: 'Params',
      //   params: {
      //     id: '123'
      //   }
      // })
    }
  }
}
</script>
接收参数页面(ParamsPage.vue)
Plain 复制代码
<template>
  <div>
    <h2>动态路由接收页</h2>
    <p>用户ID:{{ $route.params.id }}</p>
  </div>
</template>

<script>
export default {
  mounted() {
    console.log(this.$route.params) // { id: '123' }
  }
}
</script>

4. 核心区别总结

特性 查询参数传参 ($route.query) 动态路由传参 ($route.params)
URL 示例 /query?name=张三&age=25 /params/123
适用场景 适合传递多个参数,如筛选条件 适合传递单个关键参数,如ID
路由配置 无需特殊配置 需要在路由中定义 :参数名
刷新页面 参数不会丢失 参数不会丢失
相关推荐
kyriewen113 分钟前
你等的Babel编译,够喝三杯咖啡了——用Rust重写的SWC,只需眨个眼
开发语言·前端·javascript·后端·性能优化·rust·前端框架
IT_陈寒15 分钟前
SpringBoot自动配置坑了我,原来要这样绕过去
前端·人工智能·后端
东方小月25 分钟前
Claude Code 完整上手指南:MCP、Skills、第三方模型配置一次搞定
前端·人工智能·后端
XZ探长1 小时前
基于 Trae Solo 移动办公修复 Vue3 前端服务问题
前端
逍遥德1 小时前
AI时代,计算机专业大学生学习指南
java·javascript·人工智能·学习·ai编程
蝎子莱莱爱打怪1 小时前
Claude Code 省 Token 小妙招:RTK + Caveman 组合拳
前端·人工智能·后端
Rkgua1 小时前
JS中模拟函数重载的使用
javascript·jquery
竹林8181 小时前
用 wagmi v2 和 Next.js 14 硬扛 NFT 市场前端:从合约调用失败到批量上架,我踩了这些坑
javascript·next.js
Momo__2 小时前
Vue 3.6 Vapor Mode:跳过虚拟 DOM,性能极致优化
前端·vue.js
少年白马醉春风丶2 小时前
从零构建 AIGC 无限画布:AIGCCanvasFlow 技术全解析
前端·后端·aigc