详解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 相关文章推荐
《JavaScript高级程序设计》阅读笔记(三) ECMAScript中的引用类型
Feb 27 Javascript
浅谈JavaScript 框架分类
Nov 10 Javascript
javascript中setTimeout和setInterval的unref()和ref()用法示例
Nov 26 Javascript
windows8.1+iis8.5下安装node.js开发环境
Dec 12 Javascript
jQuery+ajax实现动态执行脚本的方法
Jan 27 Javascript
JS自定义选项卡函数及用法实例分析
Sep 02 Javascript
浅谈React 属性和状态的一些总结
Nov 21 Javascript
Vue实现virtual-dom的原理简析
Jul 10 Javascript
详解vue中点击空白处隐藏div的实现(用指令实现)
Apr 19 Javascript
4 种滚动吸顶实现方式的比较
Apr 09 Javascript
通过layer实现可输入的模态框的例子
Sep 27 Javascript
jquery实现鼠标悬浮弹出气泡提示框
Dec 23 jQuery
实例讲解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
dedecms中常见问题修改方法总结
2007/03/21 PHP
最新用php获取谷歌PR值算法,附上php查询PR值代码示例
2011/12/25 PHP
用mysql_fetch_array()获取当前行数据的方法详解
2013/06/05 PHP
php 模拟POST提交的2种方法详解
2013/06/17 PHP
PHP 5.6.11 访问SQL Server2008R2的几种情况详解
2016/08/08 PHP
php进程daemon化的正确实现方法
2018/09/06 PHP
在Laravel中使用MongoDB的方法示例
2019/11/11 PHP
二级域名或跨域共享Cookies的实现方法
2008/08/07 Javascript
Ext JS 4实现带week(星期)的日期选择控件(实战二)
2013/08/21 Javascript
form表单只提交数据而不进行页面跳转的解决方案
2013/09/18 Javascript
AngularJS包括详解及示例代码
2016/08/17 Javascript
BootStrap整体框架之基础布局组件
2016/12/15 Javascript
js遮罩效果制作弹出注册界面效果
2017/01/25 Javascript
移动端手指放大缩小插件与js源码
2017/05/22 Javascript
JS实现导出Excel的五种方法详解【附源码下载】
2018/03/15 Javascript
浅谈vue项目打包优化策略
2018/09/29 Javascript
详解JavaScript的内存空间、赋值和深浅拷贝
2019/04/17 Javascript
python使用cookie库操保存cookie详解
2014/03/03 Python
在python的WEB框架Flask中使用多个配置文件的解决方法
2014/04/18 Python
Python实现微信公众平台自定义菜单实例
2015/03/20 Python
整理Python最基本的操作字典的方法
2015/04/24 Python
python调用java模块SmartXLS和jpype修改excel文件的方法
2015/04/28 Python
python 函数内部修改外部变量的方法
2018/12/18 Python
Python多线程原理与用法实例剖析
2019/01/22 Python
django框架基于queryset和双下划线的跨表查询操作详解
2019/12/11 Python
TensorFlow绘制loss/accuracy曲线的实例
2020/01/21 Python
keras.layer.input()用法说明
2020/06/16 Python
哪种Python框架适合你?简单介绍几种主流Python框架
2020/08/04 Python
pycharm激活码2020最新分享适用pycharm2020最新版亲测可用
2020/11/22 Python
html5表单及新增的改良元素详解
2016/06/07 HTML / CSS
英国最大的在线运动补充剂商店:Discount Supplements
2017/06/03 全球购物
4s店总经理岗位职责
2013/12/31 职场文书
施工员岗位职责
2014/03/16 职场文书
银行贷款承诺书
2014/03/29 职场文书
餐厅周年庆活动方案
2014/08/25 职场文书
上诉状格式
2015/05/23 职场文书