vuex 多modules 下的映射写法!

本文介绍了在Vuex中如何在多模块环境下进行state的映射和区分,提到了在组件about.vue中使用modulea.js模块的情况。在组件内部,state的映射需要特别注意,而getters和actions则不需要做区分。文章通过截图展示了具体的使用方法,并预告下篇将探讨加入namespace后的写法变化。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import Vue from "vue";
import Vuex from "vuex";

Vue.use(Vuex);
import modulea from "./modulea"
export default new Vuex.Store({
  state: {
    message: "hello action",
    name: "xiaoming"
  },
  mutations: {
    set_message(state, args) {
      state.message = args;
    }
  },
  actions: {
    setMessage({ commit }, args) {
      commit("set_message", args);
    }
  },
  getters: {
    newMessage(state) {
      return state.message.split("").reverse().join("");
    }
  },
  modules: {
    a: modulea
  }
});

 

modulea.js

const user = {
    namespace: true,
    state: {
        "name": "zz"
    },
    actions: {
        deal1({ commit }, args) {
            console.log("deal1");
        }
    },
    getters: {
        title() {
            return "wyj";
        }
    },
    mutations: {

    },
    modules: {

    }
}
export default user;

然后在组件about.vue 中使用

我要说的是state 区分,别的 getters actions 不区分

about.vue

<template>
  <div>
    <p>{{title}}</p>
    <el-button @click="deal1">setMessage</el-button>
  </div>
</template>

<script>
import { mapState, mapActions, mapGetters } from "vuex";
export default {
  computed: {
    ...mapState({
      name: state => state.name,
      name2: state => state.a.name,
      message: state => state.message
    }),
    // 不带 namespace:true 则不带命名空间,
    ...mapGetters(["newMessage", "title"])
  },
  methods: {
    ...mapActions(["deal1"])
  }
};
</script>

<style lang="scss" scoped>
</style>

在这里我们分别截图下:

好了,这篇就到这里,下一篇,我们就得加namespace 了,这个写法又得变

vuexmodules是用来将store分割成模块的功能。每个模块都有自己的state、mutation、action和getter,并且可以嵌套子模块。\[2\]通过使用modules,可以将应用的状态进行模块化管理,使得代码更加清晰和可维护。在使用modules时,可以将根模块放在modules文件夹的外面,也可以放在里面,最后在index文件中进行整合。\[1\]在index.js文件中,可以通过import语句引入子模块,并在modules对象中进行注册。\[3\]每个子模块都可以有自己的状态参数、mutations、actions和getters,并且可以通过命名空间来进行区分。\[2\]通过使用modules,可以更好地组织和管理vuex的状态。 #### 引用[.reference_title] - *1* *3* [vue - vuex详细讲解和modules模块化的使用](https://blog.youkuaiyun.com/qq_43886365/article/details/126893817)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [vuex总结(六)——module](https://blog.youkuaiyun.com/weixin_47450807/article/details/123104614)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值