# @fesjs/plugin-vuex ## 介绍 集成vuex插件 增强vuex,导出所有的`mutations`、`actions`和`getter`的事件类型,编辑器提示 约定模式,module和plugin定义放在stores目录下,文件名包含plugin被解析为插件,无需额外配置,定义即可用。 ``` └── src ├── pages │ └── index.vue └── stores │ └── foo │ │ └── bar.js │ ├── counter.js │ ├── plugin-logger.js │ ├── user.js └── app.js ``` ::: tip 为了防止`fesjs`与`vuex`的export冲突,fesjs不提供导出vuex的任何api。你可以直接使用vuex的api ```js import { useStore } from 'vuex'; ``` ::: ## 启用方式 在 `package.json` 中引入依赖: ```json { "dependencies": { "@fesjs/fes": "^2.0.0", "@fesjs/plugin-vuex": "^2.0.0" } } ``` ## 配置 在 `.fes.js` 中配置: ```js export default { vuex: { strict: true // 开启严格模式 } } ``` ## 场景使用 先定义在stores下定义user模块,包含嵌套模块 stores/user.js ```js export default { namespaced: true, state: () => ({ name: 'aring', age: 20 }), actions: { login() { return new Promise((reslove) => { setTimeout(() => { console.log('login'); reslove('OK'); }, 1000); }); } }, modules: { address: { state: () => ({ province: '广东省', city: '深圳市', zone: '南山区' }), getters: { address(state) { return state.province + state.city + state.zone; } } } } }; ``` stores/foo/bar.js ```js export default { namespaced: true, state: () => ({ count: 0 }), mutations: { increment(state) { state.count++; } }, getters: { doubleCount(state) { return state.count * 2; } }, actions: { asyncIncrement({ commit }) { setTimeout(() => { commit('increment'); }, 2000); } } }; ``` ::: tip 导出的`mutations`、`actions`和`getter`的事件类型,将会按文件命名; 如`ACTION_TYPES.user.login`指向user模块中actions的login方法 如`GETTER_TYPES.user.address`指向user模块中嵌套的address getter 如`MUTATION_TYPES.fooBar.increment`指向foo/bar模块中mutations的increment方法 ::: 在vue文件中使用store ```vue { "name": "store", "title": "vuex测试" } ``` ::: tip 由于该插件注册在onAppCreated中,如果在onAppCreated及之前使用useStore时,获取不到vuex实例 `fesjs`导出了vuex实例`store`,如在app.js文件中 ```js import { store, GETTER_TYPES } from '@fesjs/fes'; console.log(store.getters[GETTER_TYPES.user.address]) ``` ::: ## vuex插件 stores文件夹下的文件名包含plugin被解析为插件,vuex插件写法参考[官方文档](https://next.vuex.vuejs.org/guide/plugins.html) ## API ### store * 类型 `Object` * vuex实例 ### MUTATION_TYPES * 类型 `Object` * mutation的所有事件类型 ### GETTER_TYPES * 类型 `Object` * getter的所有方法名 ### ACTION_TYPES * 类型 `Object` * action的所有事件类型