vuex-store模块化配置

一、目录结构: src -> js -> modules

1. 在modules下新建文件夹,文件夹名称按模块功能命名

如:

modules ———— home  -> homeModule.js
        |
        ———— modal  -> modalModule.js 

2. 在modules 下新建stores.js,注册所有状态

import homeState from './homeModule.js'
import modalState from './modalModule.js'

export const modules = {
    modules: {
        homeState,
        modalState
    }
}

3. 在入口文件,如main.js中引用 stores.js

import Vue from 'vue'
import Vuex from 'vuex'
import router from '@/js/router'
import { modules } from '@/js/modules/stores.js'
import HelloWorld from './HelloWorld'

Vue.config.productionTip = false
Vue.use(Vuex)

// 状态管理
const store = new Vuex.Store(modules);

new Vue({
    el: '#app',
    router,
    store,
    components: { HelloWorld },
    template: '<HelloWorld/>'
})

二、homeModule.js结构

export default module = {
    state: {
        count: 1
    },
    mutations: {
        increment(state, componentData) {
            // 变更状态
            state.count =  state.count + componentData
        }
    },
    actions: {
        // actions一般是处理异步逻辑
        incrementData(context, componentData) {
            context.commit('increment', componentData);
        }
    }
}

转载于:https://www.cnblogs.com/yhquan/p/10369140.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值