本文主要为大家详细介绍了vue-router实现tab标签页的相关方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。
vue-router 是 vue.js 官方的路由插件,适合用于构建标签页应用。vue 的标签页应用是基于路由和组件的,路由用于设定访问路径,并将路径和组件映射起来,vue-router 会把各个组件渲染到正确的地方。
首先,.vue中的内容非常简单,b988a8fd72e5e0e42afffd18f951b277创建标签,并指定路径,975b587bf85a482ea10b0a28848e78a4渲染路由匹配到的组件。
<template>
<p id="account">
<p class="tab">
<!-- 使用 router-link 组件来导航. -->
<!-- 通过传入 `to` 属性指定链接. -->
<!-- <router-link> 默认会被渲染成一个 `<a>` 标签 -->
<router-link to="/account/course">我的课程</router-link>
<!-- 注意这里的路径,course和order是account的子路由 -->
<router-link to="/account/order">我的订单</router-link>
</p>
<!-- 路由出口 -->
<!-- 路由匹配到的组件将渲染在这里 -->
<router-view></router-view>
</p>
</template>
结构很简单,我们有一个账户页 account,account 中还包含两个标签页,分别是课程 course 和订单 order。
在写路由的时候,需要注意页面间层级关系,开始我是这样写的:
import vue from 'vue'
import router from 'vue-router'
import account from ...
import courselist from ...
import orderlist from ...
vue.use(router)
export default new router({
routes: [
{
path: '/account',
name: 'account',
component: account
},
{
path: '/my-course',
name: 'course',
component: courselist
},
{
path: '/my-order',
name: 'order',
component: orderlist
}
]
})
这样做会使得点击 <router-link> 时,跳转到新页面,而不是在 <router-view> 中显示组件。
正确的路由应该这样写:
routes: [
{
path: '/account',
name: 'account',
component: account,
children: [
{name: 'course', path: 'course', component: courselist},
{name: 'order', path: 'order', component: orderlist}
]
}
]
注册一个根路由 account,将 course 和 order 注册为 account 中的子路由,和 b988a8fd72e5e0e42afffd18f951b277 中 to=account/course 对应。
刚开始做 vue,这个问题困扰了很久,特此记录。
关于vue.js组件的教程,请大家点击专题vue.js组件学习教程、vue.js前端组件学习教程,进行学习。
相关推荐:
关于jqueryui tab标签页示例代码
javascript代码分享:tab标签的切换
js与jquery分别实现tab标签页功能的方法
以上就是vue-router实现tab标签页的详细内容。