博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue自动路由-单页面项目(非build时构建)
阅读量:5836 次
发布时间:2019-06-18

本文共 1203 字,大约阅读时间需要 4 分钟。

博客中自动路由的原理?

答:简单点说,就是在请求页面时,根据url进行动态添加路由。

与其它自动路由博客的区别?

目前网上的博客,一般都是在build的时候进行动态路由添加,而本博客,采用的是在获得url请求的时候,进行动态添加。

自动路由有什么限制吗?

答:有,因为是通过url进行动态添加,所以,在指定文件夹下,组件文件的相对路径必须与url有一定的关系。当前demo项目,url路径与modules文件夹下的组件相对路径一致。例如:

url地址:localhost:5000/home/index

组件路径:modules/home/index/index.vue

此方式的自动路由能做些什么?

答:

1.动态权限控制:在匹配不上路由时,请求后台获取是否有权限,根据后台的反馈处理是否添加路由(是否允许访问)。

2.自动跳转首页、404页面等页面

项目demo地址

具体步骤

1.组件生成

在router文件夹下添加import.js文件,代码如下图:

 源码:

module.exports = file => () => import('@/modules/' + file + '.vue')

  

2.拦截路由

 在src目录下,添加autoroute.js文件,代码如下图:

源码:

import router from './router'const _import = require('./router/import')// 获取组件的方法router.beforeEach(async (to, from, next) => {  // 默认的首页页面  if (to.fullPath === '/') {    next('/home/index')  } else if (to.matched.length === 0) {    // 获取组件路径    let componentpath = to.fullPath.substring(1) + '/' + to.fullPath.substring(to.fullPath.lastIndexOf('/') + 1)    // 添加路由    router.addRoutes([{      path: to.fullPath,      name: to.fullPath.substring(to.fullPath.lastIndexOf('/') + 1),      component: _import(componentpath)    }])    // 路由重匹配    next({ ...to, replace: true })  } else {    next()  }})

  

转载于:https://www.cnblogs.com/zhuxiaoxiao/p/10795157.html

你可能感兴趣的文章
Android--音乐播放器
查看>>
二分查找java代码
查看>>
JavaScript事件练习
查看>>
代理模式
查看>>
vs2010的11个调试技巧和方法
查看>>
关于k-means聚类算法的matlab实现
查看>>
Git分支2
查看>>
在域环境下禁用USB存储设备的方法
查看>>
一键安装Gitlab后的备份、迁移与恢复
查看>>
因为本人工作繁忙,精力有限,本博客停止更新。有兴趣的博友可以关注我在CSDN上的主博客...
查看>>
读取网站字节流与字符流
查看>>
Unix整理笔记——Unix基础——里程碑M1
查看>>
软考高项学员:2016年4月13日作业
查看>>
CentOS+postfix+ExtMail+amavisd-new+Spam_Locker+DSpam配置指南:六、配置Apache
查看>>
lamp下搭建discuz论坛
查看>>
防止ACCESS数据库被下载的9种方法
查看>>
zabbix学习(十四)zabbix 实战短信报警之调用短信接口
查看>>
#pragma once && #ifndef
查看>>
office2007安装时,提示找不到Office.zh-cn下的OfficeMUI.msi解决方法
查看>>
JIRA WIKI 安装详解 for Linux
查看>>