【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设计风格。
相关推荐
2301_8127314113 小时前
CSS3笔记
前端·笔记·css3
ziblog13 小时前
CSS3白云飘动动画特效
前端·css·css3
越努力越幸运50813 小时前
CSS3学习之网格布局grid
前端·学习·css3
半斤鸡胗13 小时前
css3基础
前端·css
ziblog13 小时前
CSS3创意精美页面过渡动画效果
前端·css·css3
akangznl13 小时前
第四章 初识css3
前端·css·css3·html5
会豪13 小时前
深入理解 CSS3 滤镜(filter):从基础到实战进阶
前端·css·css3
头顶一只喵喵13 小时前
CSS3进阶知识:CSS3盒子模型,box-sizing:content-box和box-sizing:border-box的讲解
前端·css·css3
小飞大王66614 小时前
css进阶用法
前端·css
普通网友14 小时前
新手必看!HCCDA-HarmonyOS & Cloud Apps 实验保姆级教程
javascript·angular.js