index.js 771 B

1234567891011121314151617181920212223242526272829
  1. import Vue from 'vue';
  2. import Vuex from 'vuex';
  3. import getters from './getters';
  4. import mutations from './mutation';
  5. Vue.use(Vuex);
  6. // https://webpack.js.org/guides/dependency-management/#requirecontext
  7. const modulesFiles = require.context('./modules', true, /\.js$/);
  8. // you do not need `import app from './modules/app'`
  9. // it will auto require all vuex module from modules file
  10. const modules = modulesFiles.keys().reduce((modules, modulePath) => {
  11. // set './app.js' => 'app'
  12. const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1');
  13. const value = modulesFiles(modulePath);
  14. modules[moduleName] = value.default;
  15. return modules;
  16. }, {});
  17. console.log(modules);
  18. const store = new Vuex.Store({
  19. modules,
  20. mutations,
  21. getters
  22. });
  23. export default store;