时间:2021-05-18
在软件开发的过程中,"自动化"这个词出现的频率是比较高的。自动化测试,自动化数据映射以及各式的代码生成器。这些词语的背后,也说明了在软件开发的过程中,对于那些重复、千篇一律的事情。人们总是想让它自己完成,来解放我们的双手。
“懒惰”是进步的动力
为什么要自动化路由
路由自动化在于解决以下的问题:
目的很简单,在开发过程中,开发者仅需要做两件事即可:
开发过程中只需要做这两步,无需再去关心路由对象如何编写。
甚至可以忽略第一步,对于小型项目而言。
自动化路由规则
这些规则一部分是给开发者看,另一部分是给程序看的:
以上便是我们制定的自动化路由规则。
定义
先提取出三个概念:
自动化路由的提供者,它就是对外开放的接口,开发者只需要使用它就可以。
视图,指的是一个视图组件的相关信息,比如路径、名称等等。
路由,指的是解析视图之后对应的路由对象,用于生成 vue-router 的路由对象。
开始开发
由于代码过长,这里将代码上传至 Github , 有兴趣的童鞋可以去看看。
这里只描述一下整体流程以及关键部分的代码思路。
其中最关键的地方便是通过 require.context 获取到的文件列表还原成原来的树形结构。
还原成树形结构之后就可以对应树形结构进行路由对象的生成了。
首先将文件列表进行排序,根据文件的深度进行排序,深度浅的在前,深的在后。
_getViews(dir) { let views = []; let keys = dir.keys(); for (let index in keys) { let path = keys[index]; let component = dir(path); views.push(View.create(path, component.default || component)) } views = views.sort((x, y) => { return x.Deep > y.Deep ? 1 : -1; }); return views;}根据排序后的列表对目录结构进行还原:
/** * 解析views,生成对应的目录结构 * @private */_generateDirectory() { for (let index in this._views) { let view = this._views[index]; this._directory.addView(view); }}addView 方法:
addView(view) { if(this.isCurrentDirectoryView(view)) { this._views.push(view); } else if(this._isInSubDirectory(view)) { this._addInSubDirectory(view); } else { let newSubDirectory = this._createSubDirectory(view); newSubDirectory.addView(view); this._subDirectory.push(newSubDirectory); }}对于目录还原时有三种可能:
将目录还原后,就可以根据目录生成对应的路由对象。并且在生成时可以做一些定制化的需求,比如开篇提出来的需求:
使用方法,将 router.js 中的路由对象替换成自动生成的即可:
import Vue from 'vue'import Router from 'vue-router'import Generator from './routerGenerator/generator';Vue.use(Router);let generator = new Generator(require.context('./views', true, /\.vue$/));export default new Router({ routes: [generator.generate()]})目录结构如下:
效果如下:
github地址: https://github.com/WhileKing/ea-router
npm地址: https:///package/ea-router
npm包安装使用:
npm i ea-router以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了python自动化测试之异常及日志操作。分享给大家供大家参考,具体如下: 为了保持自动化测试用例的健壮性,异常的捕获及处理,日志的记录对掌握自动
一:自动化了解知识工具安装什么样的项目适合做自动化?自动化测试一般在什么阶段开始实施?你们公司自动化的脚本谁来维护?如何维护?自动化用例覆盖率是多少?自动化的原
1.信息化电子商务时代,物流信息化是电子商务的必然要求。2.自动化自动化的基础是信息化回,自动化的核心是答机电一体化,自动化的外在表现是无人化,自动化的效果是省
AG自动化技术退钱:自动化技术退钱应用计划方案一、店家难题你是不是在应用AG自动化技术退钱的情况下遇到过以下的难题!!!!!!二、AG计划方案1、出示自动化技术
对象的深拷贝与浅拷贝的区别如下:浅拷贝:仅仅复制对象的引用,而不是对象本身;深拷贝:把复制的对象所引用的全部对象都复制一遍。一.浅拷贝的实现浅拷贝的实现方法比较