集团官网
  • 国家级全民数字素养与技能培训基地
  • 河南省第一批产教融合型企业建设培育单位
  • 郑州市数字技能人才(码农)培养评价联盟

云和大咖说:基于require.context的模块化自动引入功能实现

编辑:云和数据 日期:2021-01-20 09:48

基于框架的项目开发中,我们在很多时候都需要将文件按模块拆分,以此来达到功能复用的目的。在拆分模块后,我们面临的往往是模块的引入及使用所带来的事件成本的增加。本篇文章就为了解决这样的问题而产生的。

1 require.context是什么?

require.content 是基于webpack的一个api,它可以引入文件夹中的所有文件,并获取到文件的内容,以此来实现模块加载的功能。在前端工程中,如果遇到从一个文件夹引入很多模块的情况,可以使用这个api,它会遍历文件夹中的指定文件,然后 自动导入 ,使得不需要每次显式的调用import导入模块。

2 require.context语法分析

该api有自己的语法规则,利用对应的规则,我们可以实现对模块的自动引入的操作。

2.1 基础语法

require.context(directory,useSubdirectories,regExp) 

require.contenxt有三个参数

directory

useSubdirectories

regExp

const requireComponent = require.context(

  // directory 表示其组件目录的相对路径

  './path',

  // useSubdirectories 表示是否查询其子目录

  false,

  // regExp 表示匹配基础组件文件名的正则表达式

  /Base[A-Z]\w+\.(vue|js)$/

)

3 常见应用场景

云和数据课程中包含了Vue及React课程,我们以Vue课程中的内容为例,学习如何利用require.context来实现对模块的自动加载功能,实现以下两个功能

路由模块的自动引入

vuex modules自动引入

3.1 路由模块的自动引入

3.1.1 目录分析

– router

 – routes 

   – user.js

    – posts.js

    – comemnt.js

    – category.js

  – index.js

3.1.2 代码实现

在index.js中,我们需要引入routes中的所有的模块,并在index.js中进行模块的注册工作。

import Router from 'vue-router'

// 核心代码开始

// 引入所有的模块并获取到文件名

const files = require.context('./routes', false, /\.js$/)

const _routes = []

// 对文件进行遍历

files.keys().forEach(key => {

  // 获取文件中的内容,并添加到事先创建好的数组中

 _routes.push(files(key).default)

})

// 核心代码结束

m z

3.2 vuex 模块的自动导入

3.2.1 目录分析

– store

 – modules

   – user.js

    – posts.js

    – comemnt.js

    – category.js

  – index.js

3.2.2 代码实现

在index.js中,我们需要引入modules中的所有的模块,并在index.js中进行模块的注册工作。

import Vue from 'vue'

import Vuex from 'vuex'

Vue.use(Vuex)

const context = require.context('./modules', false, /\.js$/)

//获取moudules文件下所有js文件;

const moduleStores = {}

context.keys().forEach(key => {

  // context.keys() 返回匹配成功模块的名字组成的数组

  const fileName = key.slice(2, -3)

  //通过 context(key)导出文件内容。在文件中通过 export.default 导出的,所以后边加.default

  const fileModule = context(key).default;

  moduleStores[fileName] = {

    …fileModule,

    //文件中有写可以省略;不过这样写可以不用给每个文件写入;这个属性不知道自己去查文档;

    namespaced: true,    

  }

})

export default new Vuex.Store({

  modules: {

    …moduleStores,

  },

})

以上,就是我们通过 require.context 来完成自动化模块引入的方案,通过这样的方式。我们可以节省我们开发时的一些时间。

文 / 云和数据H5高级技术专家张老师

001.jpg

云和数据作为一个深耕IT职业教育多年的教育者,目前的课程涵盖云计算、大数据、人工智能、虚拟现实、软件工程、用户体验设计、网络安全、电子商务等八大方向,结合企业实际用人需求,只为培养更多高端IT技术人才。

声明:除云和数据原创文章外,分享和转载的文章皆为促进IT技术的传播,并不代表本微信赞同其观点和对真实性负责,仅做交流学习使用,非商业用途。如有文章或图片的原作者有异议或涉及版权问题,请立即联系我们,我们将在第一时间进行改正或删除,确保您的权益,谢谢支持!

相关内容

抢先一步 鸿蒙(HarmonyOS)应用开发者高级认证 免费考! 适合人群计算机相关专业在校生(技师、中职、高职、本科、研究生)对鸿蒙(HarmonyOS)有兴趣的非计算机相关专业在校生目前正在从事移动应用的开发者目前正在从事计算机行业相关的人计算机专业高校老师所有对鸿蒙(HarmonyOS)有兴趣的人 培训方案掌握鸿蒙的核心概念和端云一体化开发、... 什么是Java的多态性(polymorphism)?它有哪些不同的形式? 多态性是Java面向对象编程的一个重要概念,它允许不同的对象以一致的方式响应同一个方法调用,具体表现为对象在运行时可以表现出多个不同的形态。多态性主要有两种不同的形式:编译时多态性(静态多态性)和运行时多态性(动态多态性)。1. 编译时多态性(静态多态性):   ... 如何学习和搭建Hadoop开发环境? Hadoop是大数据处理领域的重要平台,能够处理和分析大量数据。为了有效地利用Hadoop,我们需要学习其基础知识,并正确搭建开发环境。下面是详细的学习和搭建指南。一、学习Hadoop基础掌握基础概念和原理Hadoop主要由HDFS和MapReduce两部分组成。HDFS是分布式文件系统,Ma... UI 设计学习如何进阶成为高手 我总结了六种方法,帮助你走出舒适区,提高技能,成长为自信且经验丰富的UI设计高手一位经验丰富的 UI 设计师,往往十分看中应用程序界面的吸引力和视觉刺激,确保满足用户期望和需求。但是,如果你已经在 UI 设计圈摸爬滚打多年,仍然没有出色的作品,那你极有可能是因为陷入了一个舒适圈,UI技能一直原... 在Java中Executor和Executors的区别? 在Java中,Executor和Executors都与线程池和并发执行有关,但它们是不同的概念和类。1.ExecutorExecutor是一个接口,位于java.util.concurrent包中,用于表示一个执行任务的执行器。它只定义了一个方法:void execute(Runnable c... String类型的常见命令有哪些? String类型,也就是字符串类型,是Redis中最简单的存储类型。其value是字符串,不过根据字符串的格式不同,又可以分为3类:string是普通字符串,int整数类型,可以做自增、自减操作,float浮点类型,可以做自增、自减操作。String的常见命令有:SET:添加或者修改已经存在的...