Vue-router路由的props配置

文章详细介绍了在Vue.js中通过props向组件传递参数的三种方式:1)props值为对象,直接定义键值对;2)props值为布尔值,自动传递路由params参数;3)props值为函数,动态获取和处理$route参数。每种方法的适用场景和灵活性不同,第三种方式最为灵活,可处理params和query参数。

作用:让路由组件更方便的收到参数。

第一种写法:props值为对象

    1. 第一种写法:props值为对象,该对象中所有的key-value的组合最终都会通过props传给Detail组件
      
      children: [
          {
              name: 'xiangqing',
              path:'detail',
              component: Detail,
              // props对象中所有的key-value的组合最终都会通过props传给Detail组件
              props:{
                  id: '888',
                  title: '你好啊'
              }
          }
      
    2. 在Detail组件中使用props接收传递来的数据

<template>
  <div>
    <ul>
        <li>接收的id为{{id}}</li>
        <li>接收的title为{{title}}</li>
    </ul>
  </div>
</template>
 
<script>
export default {
    name: 'Detail',
    // 接收组件传递来的数据
    props: ['id', 'title']
}
</script>

这种写法传递的参数不灵活 一般很少使用 

第二种写法:props值为布尔值 

第二种写法:props值为布尔值,布尔值为true,则把路由收到的所有params参数通过props传给Detail组件

{
    name: 'xiangqing',
    path:'detail/:id/:title', //使用占位符声明接收params参数
    component: Detail,
    // 第二种写法:props值为布尔值,布尔值为true,则把路由收到的所有params参数通过props传给Detail组件
    props: true
}

 传递params参数

<li v-for="item in list" :key="item.id">
  <router-link :to="{
    name: 'xiangqing',
    params: {
      id: item.id,
      title: item.title
    }
  }">{{ item.title }}</router-link>
</li>

组件内部使用props接收参数

<template>
  <div>
    <ul>
        <li>接收的id为{{id}}</li>
        <li>接收的title为{{title}}</li>
    </ul>
  </div>
</template>
 
<script>
export default {
    name: 'Detail',
    // 接收组件传递来的数据
    props: ['id', 'title']
}
</script>

这种写法相对比上一种传参更为简介灵活 但是只能作用于params类型的参数 无法对query类型的参数起作用

第三种写法:props值为函数

第三种写法:props值为函数,该函数返回的对象中每一组key-value都会通过props传给Detail组件 

 {
      name: 'xiangqing',
      path:'detail/:id/:title', //使用占位符声明接收params参数
      component: Detail,
      // 第三种写法:props值为函数,该函数返回的对象中每一组key-value都会通过props传给Detail组件
      // props函数会自动调用并提供一个$route参数 可以通过$route来获取想要的数据传递给组件
      props($route) {
          return {
              id: $route.params.id||$route.query.age,
              title: $route.params.title||$route.query.name,
              // 还可以返回一些别的数据
              a: 1,
              b: "hello"
          }
      }
  }

 组件内部使用props接收参数

<template>
  <div>
    <ul>
        <li>接收的id为{{id}}</li>
        <li>接收的title为{{title}}</li>
        {{a}}-----{{b}}
    </ul>
  </div>
</template>
 
<script>
export default {
    name: 'Detail',
    // 接收组件传递的参数
    props: ['id', 'title', 'a', 'b']
}
</script>

 这种方式传递数据更为灵活 通过函数的$route参数来获取需要的数据传递给组件另外还可以携带一些其他数据 通过$route可以获取params和query两种形式的参数 相对前两种方式来说功能更加的强大

### Vue Router 中 `props` 的使用方法 在 Vue Router 中,`props` 是一种向目标组件传递数据的方式。通过设置路由中的 `props` 属性,可以将静态或动态的数据作为属性传递给对应的组件。 #### 静态 Props 当 `props` 被设置为布尔值 `true` 时,路由器会将路由参数(params)自动映射为目标组件的 `props`[^1]。这意味着如果 URL 参数发生变化,这些变化也会反映到组件的 `props` 上。 以下是静态 `props` 的示例: ```javascript const routes = [ { path: &#39;/user/:id&#39;, component: User, props: true // 自动将 route.params 映射为组件的 props } ]; ``` 在这种情况下,访问 `/user/123` 将使 `User` 组件接收到 `{ id: &#39;123&#39; }` 作为它的 `props`。 --- #### 动态 Props (函数形式) 除了简单的布尔值外,还可以将 `props` 设置为一个返回对象的函数。这种方式允许更灵活地控制传入组件的数据结构和逻辑处理。 下面是一个动态 `props` 的例子: ```javascript const routes = [ { path: &#39;/search&#39;, component: SearchResults, props: (route) => ({ query: route.query.q || &#39;&#39; }) } ]; // 假设当前URL为 /search?q=hello,则SearchResults组件将会接收 {query: &#39;hello&#39;} 作为props。 ``` 在这个场景下,无论查询字符串如何改变,都会实时更新 `SearchResults` 组件内的 `props`. --- #### 完整配置实例 为了更好地理解实际应用情况,这里给出完整的项目文件夹结构以及相关代码片段[^3]: **创建页面组件** 新建名为 `Profile.vue` 的组件位于路径 `src/views/Profile.vue` 下面: ```html <template> <div class="profile"> 用户ID: {{ userId }} </div> </template> <script> export default { name: "Profile", props: [&#39;userId&#39;], // 接收父级传来的prop }; </script> ``` **定义路由规则** 编辑 `router/index.js`, 添加如下内容: ```javascript import { createRouter, createWebHistory } from &#39;vue-router&#39;; import Profile from &#39;../views/Profile.vue&#39;; const router = createRouter({ history: createWebHistory(), routes: [ { path: &#39;/profile/:id&#39;, name: &#39;Profile&#39;, component: Profile, props: true // 启用props功能 }, ], }); export default router; ``` 现在当你导航至 `/profile/456` 地址的时候,`Profile` 组件就会显示 “用户ID: 456”。 --- #### 总结 Vue Router 提供了多种方式让开发者能够轻松实现跨组件间通信的需求。无论是简单直接还是复杂计算后的结果都可以借助于 `props` 来完成传输任务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值