详解vue路由篇(动态路由、路由嵌套)


Posted in Javascript onJanuary 27, 2019

什么是路由?网络原理中,路由指的是根据上一接口的数据包中的IP地址,查询路由表转发到另一个接口,它决定的是一个端到端的网络路径。

web中,路由的概念也是类似,根据URL来将请求分配到指定的一个'端'。(即根据网址找到能处理这个URL的程序或模块)
使用vue.js构建项目,vue.js本身就可以通过组合组件来组成应用程序;当引入vue-router后,我们需要处理的是将组件(components)映射到路由(routes),然后在需要的地方进行使用渲染。

一、基础路由

1、创建vue项目,执行vue init webpack projectName命令,默认安装vue-router。项目创建后,在主组件App.vue中的HTML部分:

<template>
 <div id="app">
  <router-view/>
 </div>
</template>

上述代码中,<router-view/>是路由出口,路由匹配到的组件将渲染在这里。

2、文件router/index.js中:

import Vue from 'vue' // 导入vue插件
import Router from 'vue-router' // 导入vue-router
import HelloWorld from '@/components/HelloWorld' // 导入HelloWorld组件

Vue.use(Router) // 引入vue-router
export default new Router({
 routes: [
  {
   path: '/', // 匹配路由的根路径
   name: 'HelloWorld',
   component: HelloWorld
  }
 ]
})

以上代码比较简单,一般的导入、引用操作,其中Vue.use()具体什么作用?

个人理解:Vue.use(plugin, arguments)就是执行一个plugin函数,或执行plugin的install方法进行插件注册(如果plugin是一个函数,则执行;若是一个插件,则执行plugin的install方法...);并向plugin或其install方法传入Vue对象作为第一个参数;如果有多个参数,use的其它参数作为plugin或install的其它参数。(具体需要分析源码,在此不再过多解释)

二、动态路由

什么是动态路由?动态路由是指路由器能够自动的建立自己的路由表,并且能够根据实际情况的变化实时地进行调整。

1、在vue项目中,使用vue-router如果进行不传递参数的路由模式,则称为静态路由;如果能够传递参数,对应的路由数量是不确定的,此时的路由称为动态路由。动态路由,是以冒号为开头的(:),例子如下:

export default new Router({
 routes: [
  {
   path: '/',
   name: 'HelloWorld',
   component: HelloWorld
  }, {
   path: '/RouterComponents/:id',
   name: 'RouterComponents',
   component: RouterComponents
  }
 ]
})

2、路由跳转,执行方式有两大类;

第一大类:router-link模式,直接把参数写在to属性里面:

<router-link :to="{name:'RouterComponents',params:{id:110}}">跳转</router-link>

第二大类:$router.push()模式,代码如下:

methods: {
  changeFuc (val) {
   this.$router.push({
    name: 'RouterComponents',
    params: {id: val}
   })
  }
}

或者:

methods: {
  changeFuc (val) {
   this.$router.push({
    path: `/RouterComponents/${val}`,
   })
  }
}

三、嵌套路由

vue项目中,界面通常由多个嵌套的组件构成;同理,URL中的动态路由也可以按照某种结构对应嵌套的各层组件:

export default new Router({
 routes: [
  {
   path: '/', // 根路由
   name: 'HelloWorld',
   component: HelloWorld
  }, {
   path: '/RouterComponents/:id',
   component: RouterComponents,
   children: [
    {
     path: '', // 默认路由
     name: 'ComponentA', // 当匹配上RouterComponents后,默认展示在<router-view>中
     component: ComponentA
    },
    {
     path: '/ComponentB',
     name: 'ComponentB',
     component: ComponentB
    },
   ]
  }
 ]
})

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

Javascript 相关文章推荐
Jquery写一个鼠标拖动效果实现原理与代码
Dec 24 Javascript
JS+CSS实现六级网站导航主菜单效果
Sep 28 Javascript
jQuery遮罩层效果实例分析
Jan 14 Javascript
JS实现将Asp.Net的DateTime Json类型转换为标准时间的方法
Aug 02 Javascript
Angularjs的Controller间通信机制实例分析
Nov 07 Javascript
纯js实现倒计时功能
Jan 06 Javascript
JS 调试中常见的报错问题解决方法
May 20 Javascript
浅析node应用的timing-attack安全漏洞
Feb 28 Javascript
Vue render渲染时间戳转时间,时间转时间戳及渲染进度条效果
Jul 27 Javascript
原生JS实现动态加载js文件并在加载成功后执行回调函数的方法
Dec 30 Javascript
jQuery事件多次绑定与解绑问题实例分析
Feb 19 jQuery
操作按钮悬浮固定在微信小程序底部的实现代码
Aug 02 Javascript
实例讲解JS中pop使用方法
Jan 27 #Javascript
Vue.js实现的购物车功能详解
Jan 27 #Javascript
JS温故而知新之变量提升和时间死区
Jan 27 #Javascript
vue组件文档(.md)中如何自动导入示例(.vue)详解
Jan 25 #Javascript
命令行批量截图Node脚本示例代码
Jan 25 #Javascript
Node.js 进程平滑离场剖析小结
Jan 24 #Javascript
Vue.js样式动态绑定实现小结
Jan 24 #Javascript
You might like
傻瓜化配置PHP环境――Appserv
2006/12/13 PHP
php 过滤危险html代码
2009/06/29 PHP
php操作mongoDB实例分析
2014/12/29 PHP
一个无限级XML绑定跨框架菜单(For IE)
2007/01/27 Javascript
js使用函数绑定技术改变事件处理程序的作用域
2011/12/26 Javascript
jquery插件开发方法(初学者)
2012/02/03 Javascript
js生成动态表格并为每个单元格添加单击事件的方法
2014/04/14 Javascript
AngularJS+Node.js实现在线聊天室
2015/08/28 Javascript
jQuery的图片轮播插件PgwSlideshow使用详解
2016/08/11 Javascript
require.js 加载 vue组件 r.js 合并压缩的实例
2016/10/14 Javascript
jQuery排序插件tableSorter使用方法
2017/02/10 Javascript
Bootstrap警告框(Alert)插件使用方法
2017/03/21 Javascript
ES6新特性五:Set与Map的数据结构实例分析
2017/04/21 Javascript
详解使用angularjs的ng-options时如何设置默认值(初始值)
2017/07/18 Javascript
vue-router重定向不刷新问题的解决
2018/06/25 Javascript
Vue实现6位数密码效果
2018/08/18 Javascript
JavaScript实现小球沿正弦曲线运动
2020/09/07 Javascript
基于Vue插入视频的2种方法小结
2019/04/02 Javascript
JavaScript如何判断input数据类型
2020/02/06 Javascript
es6函数之箭头函数用法实例详解
2020/04/25 Javascript
微信小程序实现登录注册功能
2020/12/29 Javascript
详解js创建对象的几种方式和对象方法
2021/03/01 Javascript
[07:12]2014DOTA2西雅图国际邀请赛 黑马Liquid专题采访
2014/07/12 DOTA
python使用Queue在多个子进程间交换数据的方法
2015/04/18 Python
Python文件操作,open读写文件,追加文本内容实例
2016/12/14 Python
shell命令行,一键创建 python 模板文件脚本方法
2018/03/20 Python
python中字符串内置函数的用法总结
2018/09/13 Python
Python 正则表达式爬虫使用案例解析
2019/09/23 Python
flask框架自定义过滤器示例【markdown文件读取和展示功能】
2019/11/08 Python
jupyter notebook插入本地图片的实现
2020/04/13 Python
如何使用Django Admin管理后台导入CSV
2020/11/06 Python
详解H5 活动页之移动端 REM 布局适配方法
2017/12/07 HTML / CSS
建筑工程自我鉴定
2013/10/18 职场文书
二手书店创业计划书
2014/01/16 职场文书
小区环境卫生倡议书
2015/04/29 职场文书
小学生纪律委员竞选稿
2015/11/19 职场文书