vue封装超好用

const emergencys = {
  namespaced: true,
  state: {
    // selectedNode: null,
    // treeData: [],
    // serializeData: {},
    // animated: false,
    // needRB: true
    drawerShow: false
  },

  mutations: {
    SET_ONE: (state, payload) => {
      // 有完善的空间(判断方面)
      if (payload.key) {
        state[payload.key] = payload.content
      }
    },
    SET_MORE: (state, payload) => {
      if (Object.prototype.toString.call(payload) === '[object Object]') {
        const keys = Object.keys(payload)
        const keyState = Object.keys(state)
        keys.forEach(key => {
          if (keyState.includes(key)) {
            state[key] = payload[key]
          }
        })
      }
    }
  },
  actions: {
    setOneAction: ({
      commit
    }, payload) => {
      return commit('SET_ONE', payload)
    },
    setMoreAction: ({
      commit
    }, payload) => {
      return commit('SET_MORE', payload)
    }

  }
}

export default emergencys

使用,直接在项目中引入

import {
  mapGetters,
  mapActions
} from 'vuex'
  computed: {
    ...mapGetters([
      'drawerShow'
    ])
  },
 methods: {
    ...mapActions('emergencys', ['setOneAction']),
    }


index.js文件中
import emergencys from './modules/emergencys'
import getters from './getters'

Vue.use(Vuex)

const store = new Vuex.Store({
  modules: {
   
    emergencys
  },
  getters
})

export default store

getters.js中

const getters = {

  drawerShow: state => state.emergencys.drawerShow
}
export default getters


main.js文件中
import store from './store'

new Vue({
  el: '#app',
  router,
  store,
  render: h => h(App)
})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值