123456789101112131415161718192021222324252627282930 |
- import Vue from 'vue'
- import Vuex from 'vuex'
- import getters from './getters'
- import createPersistedState from 'vuex-solidification'
- Vue.use(Vuex)
- // 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
- }, {})
- const store = new Vuex.Store({
- modules,
- getters,
- plugins: [ // 默认存储所有state数据到localstorage
- createPersistedState()
- ]
- })
- export default store
|