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


Posted in Javascript onOctober 17, 2017

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前端组件学习教程,进行学习。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery.ui.progressbar 中文文档
Nov 26 Javascript
Javascript的常规数组和关联数组对比小结
May 24 Javascript
为什么要在引入的css或者js文件后面加参数的详细讲解
May 03 Javascript
原生javaScript实现图片延时加载的方法
Dec 22 Javascript
在easyUI开发中,出现jquery.easyui.min.js函数库问题的解决办法
Sep 11 Javascript
jQuery原理系列-常用Dom操作详解
Jun 07 Javascript
JS实现的手机端精简幻灯片效果
Sep 05 Javascript
angularjs利用directive实现移动端自定义软键盘的示例
Sep 20 Javascript
JavaScript实现左右滚动电影画布
Feb 06 Javascript
el-table树形表格表单验证(列表生成序号)
May 31 Javascript
利用JavaScript模拟京东按键输入功能
Dec 01 Javascript
vue 使用class创建和清除水印的示例代码
Dec 25 Vue.js
BACKBONE.JS 简单入门范例
Oct 17 #Javascript
JS获取一个表单字段中多条数据并转化为json格式
Oct 17 #Javascript
JS解决position:sticky的兼容性问题的方法
Oct 17 #Javascript
JS实现div模块的截图并下载功能
Oct 17 #Javascript
bootstrap模态框嵌套、tabindex属性、去除阴影的示例代码
Oct 17 #Javascript
AngularJS 控制器 controller的详解
Oct 17 #Javascript
VUE前端cookie简单操作
Oct 17 #Javascript
You might like
smarty section简介与用法分析
2008/10/03 PHP
php压缩HTML函数轻松实现压缩html/js/Css及注意事项
2013/01/27 PHP
将PHP从5.3.28升级到5.3.29时Nginx出现502错误
2015/05/09 PHP
PHP实现bitmap位图排序与求交集的方法
2016/07/28 PHP
PHP实现页面静态化的超简单方法
2016/09/06 PHP
php微信公众号开发之欢迎老朋友
2018/10/20 PHP
laravel 验证错误信息到 blade模板的方法
2019/09/29 PHP
JS添加删除一组文本框并对输入信息加以验证判断其正确性
2013/04/11 Javascript
jQuery实现DIV层淡入淡出拖动特效的方法
2015/02/13 Javascript
JQuery validate插件Remote用法大全
2016/05/15 Javascript
使用jquery提交form表单并自定义action的方法
2016/05/25 Javascript
原生JavaScript实现Tooltip浮动提示框特效
2017/03/07 Javascript
纯jQuery实现前端分页功能
2017/03/23 jQuery
vue 路由页面之间实现用手指进行滑动的方法
2018/02/23 Javascript
vue实现点击选中,其他的不选中方法
2018/09/05 Javascript
微信小程序按钮点击跳转页面详解
2019/05/06 Javascript
vue之封装多个组件调用同一接口的案例
2020/08/11 Javascript
Python将图片批量从png格式转换至WebP格式
2020/08/22 Python
Python获取CPU、内存使用率以及网络使用状态代码
2018/02/08 Python
使用PyCharm创建Django项目及基本配置详解
2018/10/24 Python
python导入坐标点的具体操作
2019/05/10 Python
python实现的按要求生成手机号功能示例
2019/10/08 Python
在python3.64中安装pyinstaller库的方法步骤
2020/06/02 Python
解决pytorch多GPU训练保存的模型,在单GPU环境下加载出错问题
2020/06/23 Python
django haystack实现全文检索的示例代码
2020/06/24 Python
Python之字典添加元素的几种方法
2020/09/30 Python
python 决策树算法的实现
2020/10/09 Python
AmazeUI的JS表单验证框架实战示例分享
2020/08/21 HTML / CSS
Mamaearth官方网站:印度母婴护理产品公司
2019/10/06 全球购物
校友会欢迎辞
2014/01/13 职场文书
《胖乎乎的小手》教学反思
2014/02/26 职场文书
园林设计专业毕业生求职信
2014/03/23 职场文书
民主生活会整改措施(党员)
2014/09/18 职场文书
小学生家长意见
2015/06/03 职场文书
MySql开发之自动同步表结构
2021/05/28 MySQL
Python学习之时间包使用教程详解
2022/03/21 Python