1.0

    1. import Vue from 'vue'
    2. import Vuex from 'vuex'
    3. import getters from './getters'
    4. Vue.use(Vuex)
    5. const modulesFiles = require.context('./modules', true, /\.js$/) // 获取全部js的文件名
    6. // [ './app.js', './errorLog.js', './permission.js', './settings.js', './tagsView.js', './user.js']
    7. const modules = modulesFiles.keys().reduce((modules, modulePath) => {
    8. // set './app.js' => 'app'
    9. const moduleName = modulePath.replace(/^\.\/(.*)\.\w+$/, '$1') // 去除"./"===> app errorLog
    10. console.log('moduleName', moduleName)
    11. const value = modulesFiles(modulePath) // 获取vuex全部属性
    12. console.log('1', value.default)
    13. modules[moduleName] = value.default // 每个vuex文件都赋值vuex全部属性
    14. return modules
    15. }, {})
    16. const store = new Vuex.Store({
    17. modules,
    18. getters
    19. })
    20. export default store