vue-router实现tab标签页(单页面)详解

网络编程 2021-07-04 17:32www.168986.cn编程入门
这篇文章主要为大家详细介绍了vue-router实现tab标签页的相关方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

vue-router 是 Vue.js 官方的路由插件,适合用于构建标签页应用。Vue 的标签页应用是基于路由和组件的,路由用于设定访问路径,并将路径和组件映射起来,vue-router 会把各个组件渲染到正确的地方。

,.vue中的内容非常简单,<router-link>创建标签,并指定路径,<router-view>渲染路由匹配到的组件。

<template> 
 <div id="aount"> 
 <p class="tab"> 
 <!-- 使用 router-link 组件来导航. --> 
 <!-- 通过传入 `to` 属性指定链接. --> 
 <!-- <router-link> 默认会被渲染成一个 `<a>` 标签 --> 
 <router-link to="/aount/course">我的课程</router-link> 
 <!-- 注意这里的路径,course和order是aount的子路由 --> 
 <router-link to="/aount/order">我的订单</router-link> 
 </p> 
 <!-- 路由出口 --> 
 <!-- 路由匹配到的组件将渲染在这里 --> 
 <router-view></router-view> 
 </div> 
</template> 

结构很简单,我们有一个账户页 aount,aount 中还包含两个标签页,分别是课程 course 和订单 order。
在写路由的时候,需要注意页面间层级关系,开始我是这样写的

import Vue from 'vue' 
import Router from 'vue-router' 
import Aount from ... 
import CourseList from ... 
import OrderList from ... 
 
Vue.use(Router) 
 
export default new Router({ 
 routes: [ 
 { 
 path: '/aount', 
 name: 'aount', 
 ponent: Aount 
 }, 
 { 
 path: '/my-course', 
 name: 'course', 
 ponent: CourseList 
 }, 
 { 
 path: '/my-order', 
 name: 'order', 
 ponent: OrderList 
 } 
 ] 
}) 

这样做会使得点击 <router-link> 时,跳转到新页面,而不是在 <router-view> 中显示组件。
正确的路由应该这样写

routes: [ 
 { 
 path: '/aount', 
 name: 'aount', 
 ponent: Aount, 
 children: [ 
 {name: 'course', path: 'course', ponent: CourseList}, 
 {name: 'order', path: 'order', ponent: OrderList} 
 ] 
 } 
] 

注册一个根路由 aount,将 course 和 order 注册为 aount 中的子路由,和 <router-link> 中 to="aount/course" 对应。 

刚开始做 Vue,这个问题困扰了很久,特此记录。

关于vue.js组件的教程,请大家点击专题、,进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by