【Vue实现参数传递:查询参数 vs. 动态路由】

文章目录

  • 查询参数传递
    • [1. 什么是查询参数?](#1. 什么是查询参数?)
    • [2. 在Vue中使用查询参数](#2. 在Vue中使用查询参数)
      • [步骤 1:在路由配置中定义查询参数](#步骤 1:在路由配置中定义查询参数)
      • [步骤 2:在组件中使用查询参数](#步骤 2:在组件中使用查询参数)
      • [步骤 3:在页面中生成链接](#步骤 3:在页面中生成链接)
    • [3. 查询参数传递的优势](#3. 查询参数传递的优势)
  • 动态路由传递
    • [1. 什么是动态路由?](#1. 什么是动态路由?)
    • [2. 在Vue中使用动态路由](#2. 在Vue中使用动态路由)
      • [步骤 1:在路由配置中定义动态路由](#步骤 1:在路由配置中定义动态路由)
      • [步骤 2:在组件中使用动态路由参数](#步骤 2:在组件中使用动态路由参数)
      • [步骤 3:在页面中生成链接](#步骤 3:在页面中生成链接)
    • [3. 动态路由传递的优势](#3. 动态路由传递的优势)

查询参数传递

1. 什么是查询参数?

查询参数是一种将数据附加到URL的方式,通常出现在问号(?)后面,用于传递信息。例如:/search?keyword=vue&page=1,其中keywordpage就是查询参数。

2. 在Vue中使用查询参数

Vue Router允许你在路由中定义查询参数,这样就可以在不同组件之间传递数据。

步骤 1:在路由配置中定义查询参数

javascript 复制代码
const routes = [
  {
    path: '/search',
    component: SearchComponent,
    props: (route) => ({ keyword: route.query.keyword, page: route.query.page })
  }
]

步骤 2:在组件中使用查询参数

vue 复制代码
<template>
  <div>
    <h1>搜索结果</h1>
    <p>关键词:{{ keyword }}</p>
    <p>页码:{{ page }}</p>
  </div>
</template>

<script>
export default {
  props: {
    keyword: String,
    page: Number
  }
}
</script>

步骤 3:在页面中生成链接

vue 复制代码
<router-link :to="{ path: '/search', query: { keyword: 'vue', page: 1 } }">搜索Vue</router-link>

3. 查询参数传递的优势

  • 适合传递多个参数。
  • URL可读性好,参数明确。

动态路由传递

1. 什么是动态路由?

动态路由是通过路由的路径中的占位符来传递参数的方式。例如:/user/:id,其中:id是动态的,可以根据实际情况传递不同的值。

2. 在Vue中使用动态路由

Vue Router允许定义动态路由。

步骤 1:在路由配置中定义动态路由

javascript 复制代码
const routes = [
  {
    path: '/user/:id',
    component: UserProfileComponent,
    props: true
  }
]

步骤 2:在组件中使用动态路由参数

vue 复制代码
<template>
  <div>
    <h1>用户详情</h1>
    <p>用户ID:{{ id }}</p>
  </div>
</template>

<script>
export default {
  props: {
    id: String
  }
}
</script>

步骤 3:在页面中生成链接

vue 复制代码
<router-link :to="'/user/' + userId">查看用户详情</router-link>

3. 动态路由传递的优势

  • 优雅简洁,适合传递单个参数。
  • 参数直接嵌套在路由路径中,更符合RESTful设计风格。
相关推荐
卡皮巴拉c994 分钟前
基于 wujie.js 进行微前端融合
前端
来碗疙瘩汤5 分钟前
深入解析 Vue 包:`vue` 究竟导出了什么?
前端
我命由我123455 分钟前
React - ref、回调 ref 回调执行次数的问题、createRef 函数、事件处理
前端·javascript·react.js·前端框架·html·html5·js
我命由我123457 分钟前
React - 收集表单元素、收集表单元素优化、生命周期(旧)、生命周期(新)
前端·javascript·react.js·前端框架·html·html5·js
SuperEugene8 分钟前
Monorepo + pnpm workspace 落地实操:Vue 中后台多项目 / 组件库 / 公共包管理|Vue 工程化篇
前端·javascript·vue.js·pnpm·vite·monorepo
We་ct9 分钟前
JSX & ReactElement 核心解析
前端·react.js·面试·架构·前端框架·reactjs·个人开发
白中白1213812 分钟前
杂七杂八补充系列
开发语言·前端·javascript
Xingxing?!18 分钟前
Vue2 微信小程序:页面间传递数组
前端·vue.js·uni-app
肉肉不吃 肉18 分钟前
代理服务的原理,及Vite 中具体实现方法
前端·vue.js
前端小D22 分钟前
作用域/闭包
前端·javascript