5、命名路由、命名视图

介绍

学习vue-router的一些学习笔记,所有笔记内容请看 vue-router学习笔记

命名路由

通过名称来标志一个路由,可以更加方便的使用。可以在创建Router实例的时候,在routes配置中给某个路由设置名称

const router = new VueRouter({
    routes: [
        {
            path:'/user/:userId',
            name: 'user',// 命名路由
            component: User
        }
    ]
})

连接一个命名路由,可以给 router-link 的to属性传递一个对象:

<router-link :to="{name :'user',params:{ userId: 123}}">User<router-link>

使用router.push():

router.push({name:'user',params:{ userId:123}})

上述两种方式都会导航到 /user/123
例子:

import Vue from 'vue'
import VueRouter from 'vue-router'

Vue.use(VueRouter)

const Home = { template: '<div>This is Home</div>' }
const Foo = { template: '<div>This is Foo</div>' }
const Bar = { template: '<div>This is Bar {{ $route.params.id }}</div>' }

const router = new VueRouter({
  mode: 'history',
  base: __dirname,
  routes: [
    { path: '/', name: 'home', component: Home },
    { path: '/foo', name: 'foo', component: Foo },
    { path: '/bar/:id', name: 'bar', component: Bar }
  ]
})

new Vue({
  router,
  template: `
    <div id="app">
      <h1>Named Routes</h1>
      <p>Current route name: {{ $route.name }}</p>
      <ul>
        <li><router-link :to="{ name: 'home' }">home</router-link></li>
        <li><router-link :to="{ name: 'foo' }">foo</router-link></li>
        <li><router-link :to="{ name: 'bar', params: { id: 123 }}">bar</router-link></li>
      </ul>
      <router-view class="view"></router-view>
    </div>
  `
}).$mount('#app')

命名视图

有时想同时(同级)展示多个视图,而不是嵌套展示,命名视图就派上用场。

<router-view></router-view>
<router-view name="a"></router-view>
<router-view name="b"></router-view>

一个视图使用一个组件渲染,因此对于同个路由,多个视图就需要多个组件。确保正确使用 components配置 (带上 s):

const router = new VueRouter({
    routes:[
        path:'/',
        components:{
            // 三个视图是同时现实的,在default视图中显示Foo组件
            // 在a视图显示Bar组件
            // 在b视图显示Baz组件
            default: Foo,
            a:Bar,
            b:Baz
        }
    ]
})
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值