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表格行换色的三种实现方法
Jun 27 Javascript
各种页面定时跳转(倒计时跳转)代码总结
Oct 24 Javascript
jQuery修改class属性和CSS样式整理
Jan 30 Javascript
javascript中slice(),splice(),split(),substring(),substr()使用方法
Mar 13 Javascript
详解javascript跨浏览器事件处理程序
Mar 27 Javascript
JavaScript判断用户名和密码不能为空的实现代码
May 16 Javascript
详解Angular中的自定义服务Service、Provider以及Factory
Apr 22 Javascript
jQuery+ajax实现局部刷新的两种方法
Jun 08 jQuery
js实现延迟加载的几种方法详解
Jan 19 Javascript
Webpack4+Babel7+ES6兼容IE8的实现
Apr 10 Javascript
微信小程序绘制图片发送朋友圈
Jul 25 Javascript
用vite搭建vue3应用的实现方法
Feb 22 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
php提示无法加载或mcrypt没有找到 PHP 扩展 mbstring解决办法
2012/03/27 PHP
PHP 等比例缩放图片详解及实例代码
2016/09/18 PHP
js下通过prototype扩展实现indexOf的代码
2010/12/08 Javascript
jquery 中多条件选择器,相对选择器,层次选择器的区别
2012/07/03 Javascript
jquery实现固定顶部导航效果(仿蘑菇街)
2013/03/21 Javascript
jQuery实现回车键(Enter)切换文本框焦点的代码实例
2014/05/05 Javascript
javascript实现rgb颜色转换成16进制格式
2015/07/10 Javascript
require.js的用法详解
2015/10/20 Javascript
nodejs中解决异步嵌套循环和循环嵌套异步的问题
2017/07/12 NodeJs
AngularJS 购物车全选/取消全选功能的实现方法
2017/08/14 Javascript
Vue使用vux-ui自定义表单验证遇到的问题及解决方法
2018/05/10 Javascript
Vue中的异步组件函数实现代码
2018/07/20 Javascript
Vue项目全局配置页面缓存之按需读取缓存的实现详解
2018/08/01 Javascript
你可能不知道的CORS跨域资源共享
2019/03/13 Javascript
解析原来浏览器原生支持JS Base64编码解码
2019/08/12 Javascript
element-ui树形控件后台返回的数据+生成组织树的工具类
2020/03/05 Javascript
vue实现移动端input上传视频、音频
2020/08/18 Javascript
jQuery实现图片切换效果
2020/10/19 jQuery
python二叉树遍历的实现方法
2013/11/21 Python
使用Python操作Elasticsearch数据索引的教程
2015/04/08 Python
Python返回真假值(True or False)小技巧
2015/04/10 Python
Python3爬虫爬取英雄联盟高清桌面壁纸功能示例【基于Scrapy框架】
2018/12/05 Python
详解Python字符串切片
2019/05/20 Python
python下的opencv画矩形和文字注释的实现方法
2019/07/09 Python
Python 占位符的使用方法详解
2019/07/10 Python
python实现kNN算法识别手写体数字的示例代码
2019/08/16 Python
Python socket模块ftp传输文件过程解析
2019/11/05 Python
HTML5 canvas基本绘图之图形组合
2016/06/27 HTML / CSS
Smallable意大利家庭概念店:设计师童装及家居装饰
2018/01/08 全球购物
优秀的自荐信要注意哪些
2014/01/03 职场文书
《陶罐和铁罐》教学反思
2014/02/19 职场文书
读书活动实施方案
2014/03/10 职场文书
2015年入党积极分子评语
2015/03/26 职场文书
2015年党员公开承诺事项
2015/04/27 职场文书
2015年六一儿童节活动方案
2015/05/05 职场文书
Java基础之this关键字的使用
2021/06/30 Java/Android