首页 > 编程 > JavaScript > 正文

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

2019-11-19 15:09:03
字体:
来源:转载
供稿:网友

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

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

<template>  <div 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>  </div> </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 中的子路由,和 <router-link> 中 to="account/course" 对应。 

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

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

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

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表