Vue.js 传递路由参数和查询参数

Vue.js 传递路由参数和查询参数

在 Vue.js 开发中,Vue Router 提供了灵活的方式来处理路由参数和查询参数,使得组件能够根据不同的路径或查询条件渲染相应的内容。

路由参数

路由参数(也称为路径参数)是 URL 路径的一部分,用于标识特定的资源或内容。在 Vue Router 中,可以通过在路由路径中使用冒号 : 定义动态路由参数。

定义动态路由

首先,在路由配置中定义带有参数的路径:

javascript 复制代码
import Vue from 'vue';
import VueRouter from 'vue-router';
import User from './components/User.vue';

Vue.use(VueRouter);

const routes = [
  { path: '/user/:id', component: User },
];

const router = new VueRouter({
  routes,
});

export default router;

在上述配置中,/user/:id 表示 id 是一个动态参数,可以匹配 /user/1/user/2 等路径。

访问路由参数

在目标组件中,可以通过 this.$route.params 访问路由参数:

vue 复制代码
<template>
  <div>
    <h2>用户 ID: {{ userId }}</h2>
  </div>
</template>

<script>
export default {
  computed: {
    userId() {
      return this.$route.params.id;
    },
  },
};
</script>

通过上述方式,组件可以根据路由参数渲染相应的内容。

查询参数

查询参数是 URL 中 ? 后面的键值对,用于传递额外的信息。在 Vue Router 中,查询参数不需要在路由配置中声明,可以直接在导航时传递。

传递查询参数

可以通过 router.push 方法传递查询参数:

javascript 复制代码
this.$router.push({ path: '/search', query: { keyword: 'Vue' } });

上述代码会导航到 /search?keyword=Vue

访问查询参数

在目标组件中,可以通过 this.$route.query 访问查询参数:

vue 复制代码
<template>
  <div>
    <h2>搜索关键词: {{ keyword }}</h2>
  </div>
</template>

<script>
export default {
  computed: {
    keyword() {
      return this.$route.query.keyword;
    },
  },
};
</script>

通过上述方式,组件可以根据查询参数执行相应的逻辑。

总结

  • 路由参数 :作为 URL 路径的一部分,需要在路由配置中定义,访问时使用 this.$route.params

  • 查询参数 :作为 URL 中 ? 后的键值对,无需在路由配置中定义,访问时使用 this.$route.query

合理使用路由参数和查询参数,可以使 Vue.js 应用的路由设计更加灵活和强大。

相关推荐
Aniugel5 分钟前
单点登录(SSO)系统
前端
颜酱5 分钟前
二叉树遍历思维实战
javascript·后端·算法
鹏多多8 分钟前
移动端H5项目,还需要react-fastclick解决300ms点击延迟吗?
前端·javascript·react.js
serioyaoyao9 分钟前
上万级文件一起可视化,怎么办?答案是基于 ParaView 的远程可视化
前端
万少15 分钟前
端云一体 一天开发的元服务-奇趣故事匣经验分享
前端·ai编程·harmonyos
WindrunnerMax17 分钟前
从零实现富文本编辑器#11-Immutable状态维护与增量渲染
前端·架构·前端框架
不想秃头的程序员19 分钟前
Vue3 封装 Axios 实战:从基础到生产级,新手也能秒上手
前端·javascript·面试
数研小生33 分钟前
亚马逊商品列表API详解
前端·数据库·python·pandas
你听得到1135 分钟前
我彻底搞懂了 SSE,原来流式响应效果还能这么玩的?(附 JS/Dart 双端实战)
前端·面试·github
不倒翁玩偶35 分钟前
npm : 无法将“npm”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。
前端·npm·node.js