Vue中使用require.context自动引入组件的方法介绍

我们项目开发中,经常需要import或者export各种模块,那么有没有什么办法可以简化这种引入或者导出操作呢?答案是肯定的,下面就为大家介绍一下require.context

require.context 是 webpack 提供的一个 API,用于创建 context,即一组具有相同上下文的模块。

使用 require.context 可以方便地加载多个模块,并且可以灵活地控制模块的加载顺序和依赖关系。

以前我们都是通过import 方式引入组件

import A from 'components/A'
import B from 'components/B'
import C from 'components/C'
import D from 'components/D'

这样很蛋疼,因为每加一个组件,可能都要写这么一句,这样有规律的事,是否可以通过自动化完成?

require.context (需要vue-cli3+的版本)

require.context(directory, useSubdirectories, regExp)
  1. directory: 要查找的文件路径
  2. useSubdirectories: 是否查找子目录
  3. regExp: 要匹配文件的正则

1.在compoents文件下随便创建index.js文件

const requireComponent = require.context('./', true, /\.vue$/)
const install = (Vue) => {
    if (install.installed) return
    install.installed
    requireComponent.keys().forEach(element => {
        const config = requireComponent(element)
        if (config && config.default.name) {
            const componentName = config.default.name
            Vue.component(componentName, config.default || config)
        }
    });
}

if (typeof window !== 'undefined' && window.Vue) {
    install(window.Vue)
}

export default {
    install
}

2.mian.js引入该js

import install from './compoents'
Vue.use(install)

总结

我们可以通过require.context可以自动化引入文件。
其实我们不单单局限于组件,路由内, 所有模块文件都是通用的, 例如路由, 接口封装模块,都是可以使用的。

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2023-12-27 17:36:03       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2023-12-27 17:36:03       106 阅读
  3. 在Django里面运行非项目文件

    2023-12-27 17:36:03       87 阅读
  4. Python语言-面向对象

    2023-12-27 17:36:03       96 阅读

热门阅读

  1. Hive-数据模型详解(超详细)

    2023-12-27 17:36:03       58 阅读
  2. 数据结构-怀化学院期末题(59)

    2023-12-27 17:36:03       54 阅读
  3. $bus的用法 vue

    2023-12-27 17:36:03       47 阅读
  4. Spring 表达式expression

    2023-12-27 17:36:03       49 阅读
  5. 相机FOV是什么英文单词的缩写,是什么意思。

    2023-12-27 17:36:03       56 阅读
  6. 前端axios与python库requests的区别

    2023-12-27 17:36:03       59 阅读
  7. effective c++ 笔记 导读/条款2-4

    2023-12-27 17:36:03       51 阅读
  8. NGINX高级技巧

    2023-12-27 17:36:03       61 阅读
  9. ElementuiPlus文件上传失败原因,一个小坑记录!

    2023-12-27 17:36:03       57 阅读
  10. 架构艺术:系统演进的精髓与实践

    2023-12-27 17:36:03       50 阅读
  11. Python实现音乐推荐系统

    2023-12-27 17:36:03       45 阅读
  12. python异常之assert语句

    2023-12-27 17:36:03       74 阅读