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 13 Javascript
Javascript 定时器调用传递参数的方法
Nov 12 Javascript
JavaScript定义类或函数的几种方式小结
Jan 09 Javascript
jQuery登陆判断简单实现代码
Apr 21 Javascript
JS图像无缝滚动脚本非常好用
Feb 10 Javascript
jquery的父子兄弟节点查找示例代码
Mar 03 Javascript
JS实现鼠标箭头变成一个燃烧烛光效果的方法
Feb 28 Javascript
JavaScript数组去重的3种方法和代码实例
Jul 01 Javascript
js将table的每个td的内容自动赋值给其title属性的方法
Oct 13 Javascript
JavaScript实现省市县三级级联特效
May 16 Javascript
如何去除vue项目中的#及其ie9兼容性
Jan 11 Javascript
Element-Ui组件 NavMenu 导航菜单的具体使用
Oct 24 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
ThinkPHP控制器间实现相互调用的方法
2014/10/31 PHP
CentOS 安装 PHP5.5+Redis+XDebug+Nginx+MySQL全纪录
2015/03/25 PHP
php cli配置文件问题分析
2015/10/15 PHP
php读取txt文件并将数据插入到数据库
2016/02/23 PHP
PHP实现统计在线人数功能示例
2016/10/15 PHP
Mac系统完美安装PHP7详细教程
2017/06/06 PHP
PHP 7.4中使用预加载的方法详解
2019/07/08 PHP
CSS+JS构建的图片查看器
2006/07/22 Javascript
扩展Jquery插件处理mouseover时内部有子元素时发生样式闪烁
2011/12/08 Javascript
jQuery+CSS实现菜单滑动伸展收缩(仿淘宝)
2013/03/22 Javascript
javaScript年份下拉列表框内容为当前年份及前后50年
2014/05/28 Javascript
javascript中bind函数的作用实例介绍
2014/09/28 Javascript
详解JavaScript的回调函数
2015/11/20 Javascript
JavaScript数据存储 Cookie篇
2016/07/02 Javascript
Node.js测试中的Mock文件系统详解
2016/11/21 Javascript
基于vue-simplemde实现图片拖拽、粘贴功能
2018/04/12 Javascript
微信小程序新手教程之启动页的重要性
2019/03/03 Javascript
jQuery zTree树插件的使用教程
2019/08/16 jQuery
基于Electron实现桌面应用开发代码实例
2020/07/07 Javascript
vuex中遇到的坑,vuex数据改变,组件中页面不渲染操作
2020/11/16 Javascript
[01:02:53]DOTA2上海特级锦标赛主赛事日 - 5 总决赛Liquid VS Secret第二局
2016/03/06 DOTA
python使用marshal模块序列化实例
2014/09/25 Python
Python中计算三角函数之cos()方法的使用简介
2015/05/15 Python
python实现电子产品商店
2019/02/26 Python
python matplotlib画图库学习绘制常用的图
2019/03/19 Python
python常用函数与用法示例
2019/07/02 Python
python批量修改图片尺寸,并保存指定路径的实现方法
2019/07/04 Python
Python3 ffmpeg视频转换工具使用方法解析
2020/08/10 Python
selenium框架中driver.close()和driver.quit()关闭浏览器
2020/12/08 Python
年终考核实施方案
2014/05/26 职场文书
2014党委书记四风对照检查材料思想汇报
2014/09/21 职场文书
暑期社会实践新闻稿
2015/07/17 职场文书
自信主题班会
2015/08/14 职场文书
2019求职信大礼包
2019/05/15 职场文书
入党转正申请书范文
2019/05/20 职场文书
Java结构型设计模式之组合模式详解
2022/09/23 Java/Android