动态导入 modules 文件夹下的所有模块

127 阅读1分钟

webpack

import Vue from 'vue'
import Vuex from 'vuex'
Vue.use(Vuex);

// 把modules文件下的 js文件返回出来
// https://webpack.js.org/guides/dependency-management/#requirecontext
const modulesFiles = require.context('./modules', true, /\.js$/)

// you do not need `import app from './modules/app'`
// it will auto require all vuex module from modules file
const modules = modulesFiles.keys().reduce((modules, modulePath) => {
	// set './app.js' => 'app'
	const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1')
	const value = modulesFiles(modulePath)
	modules[moduleName] = value.default
	return modules
}, {});

export default new Vuex.Store({
	state: {},
	mutations: {},
	getters: {},
	actions: {},
	modules,
});
}, {});

vite

const modules: any[] = [];

// 把modules文件下的 ts文件返回出来
// https://juejin.cn/post/7135282172738404365
const modulesFiles = import.meta.glob('./modules/**/*.ts', { eager: true, import: 'default' });

Object.keys(modulesFiles).forEach(key => {
    const mod = modulesFiles[key];
    const modList = Array.isArray(mod) ? mod : [mod];
    modules.push(...modList);
})

export default modules;