详解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 相关文章推荐
15个款优秀的 jQuery 图片特效插件推荐
Nov 21 Javascript
JavaScript实现select添加option
Jul 03 Javascript
整理JavaScript创建对象的八种方法
Nov 03 Javascript
跟我学习javascript的浮点数精度
Nov 16 Javascript
工作中比较实用的JavaScript验证和数据处理的干货(经典)
Aug 03 Javascript
vue自动路由-单页面项目(非build时构建)
Apr 30 Javascript
微信小程序实现元素渐入渐出动画效果封装方法
May 18 Javascript
jquery实现垂直无限轮播的方法分析
Jul 16 jQuery
selenium+java中用js来完成日期的修改
Oct 31 Javascript
Vue基于iview实现登录密码的显示与隐藏功能
Mar 06 Javascript
JavaScript前后端JSON使用方法教程
Nov 23 Javascript
详细介绍Next.js脚手架完整搭建封装
Apr 26 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
「OVERLORD」动画重要删减!雅儿贝德的背叛?至尊猎杀队结成
2020/04/09 日漫
PHP创建桌面快捷方式的实例代码
2014/02/17 PHP
django中的ajax组件教程详解
2018/10/18 PHP
javascript实现 在光标处插入指定内容
2007/05/25 Javascript
javascript 冒泡排序 正序和倒序实现代码
2010/12/14 Javascript
jquery cookie实现的简单换肤功能适合小网站
2013/08/25 Javascript
jQuery中验证表单提交方式及序列化表单内容的实现
2014/01/06 Javascript
JavaScript中几种排序算法的简单实现
2015/07/29 Javascript
jQuery form插件的使用之处理server返回的JSON, XML,HTML数据
2016/01/26 Javascript
JS中微信小程序自定义底部弹出框
2016/12/22 Javascript
select自定义小三角样式代码(实用总结)
2017/08/18 Javascript
深入浅出webpack教程系列_安装与基本打包用法和命令参数详解
2017/09/10 Javascript
ionic4+angular7+cordova上传图片功能的实例代码
2019/06/19 Javascript
微信公众号平台接口开发 菜单管理的实现
2019/08/14 Javascript
jQuery - AJAX load() 实例用法详解
2019/08/27 jQuery
JavaScript enum枚举类型定义及使用方法
2020/05/15 Javascript
[02:49:21]2019完美盛典全程录像
2019/12/08 DOTA
Python实现将n个点均匀地分布在球面上的方法
2015/03/12 Python
Python利用Nagios增加微信报警通知的功能
2016/02/18 Python
Python读取txt文件数据的方法(用于接口自动化参数化数据)
2018/06/27 Python
对Python中内置异常层次结构详解
2018/10/18 Python
对Python 除法负数取商的取整方式详解
2018/12/12 Python
Django页面数据的缓存与使用的具体方法
2019/04/23 Python
使用python搭建服务器并实现Android端与之通信的方法
2019/06/28 Python
Django REST framework内置路由用法
2019/07/26 Python
python之PyQt按钮右键菜单功能的实现代码
2019/08/17 Python
Python笔试面试题小结
2019/09/07 Python
简单了解python filter、map、reduce的区别
2020/01/14 Python
python 实现简易的记事本
2020/11/30 Python
解决Pymongo insert时会自动添加_id的问题
2020/12/05 Python
matplotlib绘制正余弦曲线图的实现
2021/02/22 Python
YII2 全局异常处理深入讲解
2021/03/24 PHP
乌鸦喝水教学反思
2014/02/07 职场文书
幼儿教师师德承诺书
2014/05/23 职场文书
我的中国梦演讲稿500字
2014/08/19 职场文书
优秀党支部申报材料
2014/12/24 职场文书