zoukankan      html  css  js  c++  java
  • Vue Vuex 严格模式+实例解析+dispatch/commit + state/getter

    1.严格模式

        import getters from './getters'
        import mutations from './mutations'
        import actions from './actions'
        export default new Vuex.Store({
          strict: true, //严格模式开启
          state: {  // 全局state
          },
          modules:{ // 外部模块
          },
          getters, // 全局getters
          mutations, // 全局mutation
          actions, // 全局actions
        })
        // 如果在vue页面中直接修改state 会报错
        this.$store.state.namespace.stateName= '直接修改state'
        // Error: [vuex] Do not mutate vuex store state outside mutation handlers.
    

    this.$store 实例解析

    // 在主入口文件main.js 或者 index.js 中,一旦引入并use了store实例后,
    // 在new Vue({})之后,
    // 便可以在任意vue文件中使用 this.$store来使用store中state/action/mutation
    import store from './store'
    Vue.use(store)
    new Vue({
      router, 
      store,
      template: '<app/>',
      components: { App }
    })
    
    // A.vue 
    console.info(this.$store)
    /**
    commit: ƒ (e,t,a)
    dispatch: ƒ (e,t)
    getters: {…} // 包含了在 new Vuex.Store({getters})的所有属性
    strict: true
    _actionSubscribers: []
    _actions:  // 包含全部的action, 全局的和module中的
    _committing: false
    _modules: c {root: s}
    _modulesNamespaceMap: // 每个单独module的命名空间 /user, /dictionary, /list
    _mutations: // 包含全部的mutations,  全局的和module中的
    _subscribers: []
    state: (...) // 包含全部的state, 全局的和module中的
    **/
    

    3. state

        // 直接调用 state 
        console.info('this.$store.state.user.flag:', this.$store.state.user.flag) 
    

    4. getters

        // 直接调用 getters(前提是在getter中声明了某个state), example: flag: state => state.user.flag,
        console.info('this.$store.getters.flag:', this.$store.getters.flag)
        // 会获取同样的值
    

    5. dispatch 带有异步操作

        // dispatch执行的 action
        // this.$store.dispatch('user/actionName')
    
        // demo
        console.info(' ##### Before dispatch #####')
        this.$store.dispatch('StartLoading')
        console.info('this.$store.state.loading:', this.$store.state.loading) // true
        this.$store.dispatch('EndLoading')
        console.info(' ##### After dispatch #####')
        console.info('this.$store.state.loading:', this.$store.state.loading) // false
    

    6. commit 无异步操作

        // commit执行的是mutation
        // this.$store.commit('namespace/mutationName')
        
        // demo
        console.info(' ##### Before commit #####')
        console.info('this.$store.state.user.flag:', this.$store.state.user.flag) // I am flag
        console.info('this.$store.getters.flag:', this.$store.getters.flag) // I am flag
        this.$store.commit('user/SET_FLAG', 'commit mutation to change state') 
        console.info(' ##### After commit #####')
        console.info('this.$store.state.user.flag:', this.$store.state.user.flag) // commit mutation to change state
        console.info('this.$store.getters.flag:', this.$store.getters.flag) // commit mutation to change state
    
    Keep learning
  • 相关阅读:
    《Unity3d-控制枪口的朝向代码》
    《Unity3D-鱼的方向 鱼的游动 控制代码》
    《unity3d-随机设置一个物体的scale的方法》
    《Unity3d-在地图中随机生成一个物体的代码》
    《Unity3D-控制检测碰撞以后触发的事件之敌人的攻击行为》
    《Unity3D-播放被打中的时候粒子的特效的代码》
    《Unity3D-敌人血条或者玩家血条控制的代码》
    《Unity3D-自动寻路功能的实现》
    Unity 行首不出现中文标点
    Unity 多级下拉菜单
  • 原文地址:https://www.cnblogs.com/leslie1943/p/13359546.html
Copyright © 2011-2022 走看看