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 相关文章推荐
javascript 词法作用域和闭包分析说明
Aug 12 Javascript
JavaScript编程的10个实用小技巧
Apr 18 Javascript
js生成随机数的过程解析
Nov 24 Javascript
举例讲解如何判断JavaScript中对象的类型
Apr 22 Javascript
Js查找字符串中出现次数最多的字符及个数实例解析
Sep 05 Javascript
JS动态计算移动端rem的解决方案
Oct 14 Javascript
jquery设置css样式的多种方法(总结)
Feb 21 Javascript
微信小程序中页面FOR循环和嵌套循环
Jun 21 Javascript
JavaScript原型继承_动力节点Java学院整理
Jun 30 Javascript
基于Vue过渡状态实例讲解
Sep 14 Javascript
关于layui 实现点击按钮添加一行(方法渲染创建的table)
Sep 29 Javascript
JS+HTML5本地存储Localstorage实现注册登录及验证功能示例
Feb 10 Javascript
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
PHP+JS无限级可伸缩菜单详解(简单易懂)
2007/01/02 PHP
PHP 页面编码声明方法详解(header或meta)
2010/03/12 PHP
PHP远程采集图片详细教程
2014/07/01 PHP
学习php设计模式 php实现装饰器模式(decorator)
2015/12/07 PHP
PHP中ltrim与rtrim去除左右空格及特殊字符实例
2016/01/07 PHP
php 获取文件行数的方法总结
2016/10/11 PHP
通过MSXML2自动获取QQ个人头像及在线情况(给初学者)
2007/01/22 Javascript
JScript中使用ADODB.Stream判断文件编码的代码
2008/06/09 Javascript
jQuery 创建Dom元素
2010/05/07 Javascript
多个表单中如何获得这个文件上传的网址实现js代码
2013/03/25 Javascript
JavaScript作用域链示例分享
2014/05/27 Javascript
JS实现简单的顶部定时关闭层效果
2014/06/15 Javascript
简单分析javascript面向对象与原型
2015/05/21 Javascript
jquery实现加载进度条提示效果
2015/11/23 Javascript
JavaScript事件 &quot;事件对象&quot;的注意要点
2016/01/14 Javascript
Nodejs如何搭建Web服务器
2016/03/28 NodeJs
easyUI combobox实现联动效果
2017/01/17 Javascript
Vue组件选项props实例详解
2017/08/18 Javascript
js原生方法被覆盖,从新赋值原生的方法
2018/01/02 Javascript
微信小程序实现发送验证码按钮效果
2018/12/20 Javascript
微信小程序页面间传递数组对象方法解析
2019/11/06 Javascript
解决element-ui里的下拉多选框 el-select 时,默认值不可删除问题
2020/08/14 Javascript
Vue多选列表组件深入详解
2021/03/02 Vue.js
Python实现基于POS算法的区块链
2018/08/07 Python
Iconfont(矢量图标)+iconmoon(图标svg互转)配合javascript实现社交分享系统
2020/04/21 Python
印尼综合在线预订网站:Tiket.com(机票、酒店、火车、租车和娱乐)
2018/10/11 全球购物
Lentiamo丹麦:购买便宜的隐形眼镜
2021/01/13 全球购物
毕业生应聘求职信
2014/07/10 职场文书
党员“四风”方面存在问题及整改措施
2014/09/24 职场文书
德能勤绩廉个人总结
2015/02/14 职场文书
装饰技术负责人岗位职责
2015/04/13 职场文书
2015年环卫工作总结
2015/04/28 职场文书
时尚女魔头观后感
2015/06/04 职场文书
2016年幼儿园教研活动总结
2016/04/05 职场文书
关于感恩老师的古诗句
2019/08/20 职场文书
如何使用Python提取Chrome浏览器保存的密码
2021/06/09 Python