vue路由可以嵌套html吗,分析vue路由篇(动态路由、路由嵌套)

这篇文章主要为大家详细介绍了分析vue路由篇(动态路由、路由嵌套),具有一定的参考价值,可以用来参考一下。

感兴趣的小伙伴,下面一起跟随512笔记的小编两巴掌来看看吧!

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

web中,路由的概念也是类似,根据URL来将请求分配到指定的一个'端'。(即根据网址找到能处理这个URL的程序或模块)

使用vue.js构建项目,vue.js本身就可以通过组合组件来组成应用程序;当引入vue-router后,我们需要处理的是将组件(components)映射到路由(routes),然后在需要的地方进行使用渲染。

一、基础路由

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

代码如下:

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

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.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后,默认展示在中

component: ComponentA

},

{

path: '/ComponentB',

name: 'ComponentB',

component: ComponentB

},

]

}

]

})

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持512笔记。

注:关于分析vue路由篇(动态路由、路由嵌套)的内容就先介绍到这里,更多相关文章的可以留意512笔记的其他信息。

关键词:vue.js

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值