vue-router中name的用法

  • Post author:
  • Post category:vue


我们常用vue中的vue-router来创建单页应用,vue-router能很方便的管理所有的单页组件。我们在定义每个路由的时候会有一个name的属性,通常我们不定义这个属性发现也没有任何问题,那么这个name到底有什么用呢?

export default new Router({
  routes: [
    {
      path: '/',
      name: 'HelloWorld',
      component: HelloWorld
    }, {
      path: '/textInner',
      name: 'textInner',
      component: text
    }, {
      path: '/text/:id',
      component: param
    }
  ]
})


第一种用法:


通过name属性,为一个页面中不同的router-view渲染不同的组件,如:将上面代码的HelloWorld渲染在 name为HelloWorld的router-view中,将textInner渲染在name为textInner的router-view中。不设置name的将为默认的渲染组件。

<template>
  <div id="app">
     <router-view></router-view>
     <router-view  name="HelloWorld"></router-view> //将渲染HelloWorld组件
     <router-view  name="textInner"></router-view>   //将渲染textInner组件
  </div>
</template>


第二种用法:


使用$router.name获取组件name值

<template>
  <div id="app">
    <p>{{ $route.name }}</p> //可以获取到渲染进来的组件的name值;点击谁的路由就显示路由的name值
    <router-view></router-view>
  </div>
</template>


第三种用法:


页面渲染时传递参数

<template>
  <div id="app">
    //向name为helloWorld的组件传参数id,值为11
    <router-link :to="{name:'helloWorld', params:{id: '11'}}">hello</router-link> 
    <router-view></router-view>
  </div>
</template>



版权声明:本文为Gimamy原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。