码迷,mamicode.com
首页 > 其他好文 > 详细

vuex中使用多模块时,如果不同模块中action有名字冲突该如何解决

时间:2020-03-30 21:38:21      阅读:380      评论:0      收藏:0      [点我收藏+]

标签:rip   bsp   getter   patch   names   login   方法   const   添加   

如果希望你的模块具有更高的封装度和复用性,你可以通过添加 namespaced: true 的方式使其成为带命名空间的模块。当模块被注册后,它的所有 getter、action 及 mutation 都会自动根据模块注册的路径调整命名

const store = new Vuex.Store({
  modules: {
    account: {
      namespaced: true,

      // 模块内容(module assets)
      state: { ... }, // 模块内的状态已经是嵌套的了,使用 `namespaced` 属性不会对其产生影响
      getters: {
        isAdmin () { ... } // -> getters[‘account/isAdmin‘]
      },
      actions: {
        login () { ... } // -> dispatch(‘account/login‘)
      },
      mutations: {
        login () { ... } // -> commit(‘account/login‘)
      },

      // 嵌套模块
      modules: {
        // 继承父模块的命名空间
        myPage: {
          state: { ... },
          getters: {
            profile () { ... } // -> getters[‘account/profile‘]
          }
        },

        // 进一步嵌套命名空间
        posts: {
          namespaced: true,

          state: { ... },
          getters: {
            popular () { ... } // -> getters[‘account/posts/popular‘]
          }
        }
      }
    }
  }
})

  这时候我们在不同模块写方法就不用担心命名冲突了

vuex中使用多模块时,如果不同模块中action有名字冲突该如何解决

标签:rip   bsp   getter   patch   names   login   方法   const   添加   

原文地址:https://www.cnblogs.com/bobo1/p/12601144.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!