vuex Module将 store 分割成模块的操作


Posted in Vue.js onDecember 07, 2020

由于使用单一状态树,应用的所有状态会集中到一个比较大的对象。当应用变得非常复杂时,store 对象就有可能变得相当臃肿。

为了解决以上问题,Vuex 允许我们将 store 分割成模块(module)。每个模块拥有自己的 state、mutation、action、getter、甚至是嵌套子模块——从上至下进行同样方式的分割:

const moduleA = {
 state: () => ({ ... }),
 mutations: { ... },
 actions: { ... },
 getters: { ... }
}
 
const moduleB = {
 state: () => ({ ... }),
 mutations: { ... },
 actions: { ... }
}
 
const store = new Vuex.Store({
 modules: {
 a: moduleA,
 b: moduleB
 }
})
 
store.state.a // -> moduleA 的状态
store.state.b // -> moduleB 的状态

补充知识:vuex实现模块化分割,在不同类别的文件中放置对应的数据及操作

目录结构为

store文件夹下有index.js 、modules文件夹,在modules文件夹下是你的模块,最好通过功能命名

一级目录:store

一级目录下文件:index.js

二级目录:modules

三级目录demo

三级目录下文件demo.js

三级目录下文件getter.js

三级目录下文件mutations.js

三级目录下文件 state,js

各文件的内容为

一级目录下index.js

import Vue from 'vue'
import Vuex from 'vuex'
import demo from './modules/demo/demo.js';
Vue.use(Vuex);
const $store = new Vuex.Store({
modules: {


demo

}
});
export default $store;

三级目录下demo.js

import state from './state.js';
import mutations from './mutations.js';
// 按需要导入
// import getters from './getters.js';
// import actions from './actions.js';

export default{
// 将导入的文件暴露出去
 state,
 mutations
}

三级目录其他文件

export default{}

最后在main.js中挂载

import Vue from 'vue'
import App from './App'
import router from './router'
import { RouterMount } from 'uni-simple-router'
//引入vuex
import store from './store'
//把vuex定义成全局组件
Vue.prototype.$store = store

Vue.config.productionTip = false

App.mpType = 'app'

const app = new Vue({
 store,
  ...App
})
app.$mount();

以上这篇vuex Module将 store 分割成模块就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Vue.js 相关文章推荐
vue图片裁剪插件vue-cropper使用方法详解
Dec 16 Vue.js
vue 在服务器端直接修改请求的接口地址
Dec 19 Vue.js
vue+element UI实现树形表格
Dec 29 Vue.js
vue使用vue-quill-editor富文本编辑器且将图片上传到服务器的功能
Jan 13 Vue.js
vue实现一个获取按键展示快捷键效果的Input组件
Jan 13 Vue.js
Vue仿Bibibili首页的问题
Jan 21 Vue.js
vue keep-alive的简单总结
Jan 25 Vue.js
vue.js实现点击图标放大离开时缩小的代码
Jan 27 Vue.js
如何在vue中使用video.js播放m3u8格式的视频
Feb 01 Vue.js
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
Mar 01 Vue.js
解决vue中provide inject的响应式监听
Apr 19 Vue.js
浅谈Vue使用Elementui修改默认的最快方法
Dec 05 #Vue.js
vue+element_ui上传文件,并传递额外参数操作
Dec 05 #Vue.js
解决vue下载后台传过来的乱码流的问题
Dec 05 #Vue.js
解决Vue-cli3没有vue.config.js文件夹及配置vue项目域名的问题
Dec 04 #Vue.js
vue基于Echarts的拖拽数据可视化功能实现
Dec 04 #Vue.js
vue使用echarts图表自适应的几种解决方案
Dec 04 #Vue.js
vue-calendar-component 封装多日期选择组件的实例代码
Dec 04 #Vue.js
You might like
有关phpmailer的详细介绍及使用方法
2013/01/28 PHP
PHP错误提示的关闭方法详解
2013/06/23 PHP
使用PHP实现生成HTML静态页面
2015/11/18 PHP
pjblog中的UBBCode.js
2007/04/25 Javascript
jquery获取子节点和父节点的示例代码
2013/09/10 Javascript
jQuery的DOM操作之删除节点示例
2014/01/03 Javascript
JavaScript对象的property属性详解
2014/04/01 Javascript
深入分析JSONP跨域的原理
2014/12/10 Javascript
jQuery实现数字加减效果汇总
2014/12/16 Javascript
js中scrollTop()方法和scroll()方法用法示例
2016/10/03 Javascript
微信小程序 时间格式化(util.formatTime(new Date))详解
2016/11/16 Javascript
js实现字符全排列算法的简单方法
2017/05/01 Javascript
详解vue-router 2.0 常用基础知识点之router.push()
2017/05/10 Javascript
javascript 跨域问题以及解决办法
2017/07/17 Javascript
使用Vue-Router 2实现路由功能实例详解
2017/11/14 Javascript
node.js中axios使用心得总结
2017/11/29 Javascript
高性能的javascript之加载顺序与执行原理篇
2018/01/14 Javascript
vue.js内置组件之keep-alive组件使用
2018/07/10 Javascript
解决Antd Table组件表头不对齐的问题
2020/10/27 Javascript
用Python抢过年的火车票附源码
2015/12/07 Python
使用python绘制常用的图表
2016/08/27 Python
Python图片裁剪实例代码(如头像裁剪)
2017/06/21 Python
python实现二维数组的对角线遍历
2019/03/02 Python
python中的数组赋值与拷贝的区别详解
2019/11/26 Python
Python zip函数打包元素实例解析
2019/12/11 Python
nginx搭建基于python的web环境的实现步骤
2020/01/03 Python
使用python求解二次规划的问题
2020/02/29 Python
浅谈pycharm导入pandas包遇到的问题及解决
2020/06/01 Python
CSS3美化表单控件全集
2016/06/29 HTML / CSS
海淘零差价,宝贝全球购: 宝贝格子
2016/08/24 全球购物
美国学校用品、教室和教学商店:Discount School Supply
2018/04/04 全球购物
土木工程实习生自我鉴定
2013/09/19 职场文书
创先争优活动心得体会
2014/09/04 职场文书
2015年党支部公开承诺书
2015/01/22 职场文书
2019年教师入党申请书
2019/06/27 职场文书
德生2P3收音机开箱评测
2022/04/30 无线电