• Vuex模块:开启命名空间



    模块开启命名空间后,享有独自的命名空间。

    复制代码
    {
        "模块1":{
            state:{},
            getters:{},
            mutations:{},
            actions:{}
        },
        "模块2":{
            state:{},
            getters:{},
            mutations:{},
            actions:{}
        }
    }
    复制代码

    mapState、mapGetters、mapMutations、mapActions第一个参数是字符串(命名空间名称),第二个参数是数组(不需要重命名)/对象(需要重命名)。

    复制代码
    mapXXXs('命名空间名称',['属性名1','属性名2'])
    
    mapXXXs('命名空间名称',{
    
      '组件中的新名称1':'Vuex中的原名称1',
    
      '组件中的新名称2':'Vuex中的原名称2',
    
    })
    复制代码

    一 项目结构

    二 main.js

    复制代码
    import Vue from "vue";
    import App from "./App.vue";
    import router from "./router";
    import store from "./store/index";
    
    Vue.config.productionTip = false;
    
    new Vue({
      router,
      store,
      render: h => h(App)
    }).$mount("#app");
    复制代码

    三 index.js

    复制代码
    import Vue from "vue";
    import Vuex from "vuex";
    import cat from "./modules/cat";
    import dog from "./modules/dog";
    
    Vue.use(Vuex);
    
    export default new Vuex.Store({
      modules: { cat, dog }
    });
    复制代码

    四 cat.js

    复制代码
    export default {
      namespaced: true,
      // 局部状态
      state: {
        name: "蓝白英短",
        age: 1
      },
      // 局部读取
      getters: {
        desc: state => "宠物:" + state.name
      },
      // 局部变化
      mutations: {
        increment(state, payload) {
          state.age += payload.num;
        }
      },
      // 局部动作
      actions: {
        grow(context, payload) {
          setTimeout(() => {
            context.commit("increment", payload);
          }, 1000);
        }
      }
    };
    复制代码

    五 dog.js

    复制代码
    export default {
      namespaced: true,
      // 局部状态
      state: {
        name: "拉布拉多",
        age: 1
      },
      // 局部读取
      getters: {
        desc: state => "宠物:" + state.name
      },
      // 局部变化
      mutations: {
        increment(state, payload) {
          state.age += payload.num;
        }
      },
      // 局部动作
      actions: {
        grow(context, payload) {
          setTimeout(() => {
            context.commit("increment", payload);
          }, 1000);
        }
      }
    };
    复制代码

    六 HelloWorld.vue

    复制代码
    <template>
      <div class="hello">
        <h3>Vuex状态树</h3>
        <div>{{this.$store.state}}</div>
        <h3>mapState</h3>
        <div>{{catName}} {{catAge}}</div>
        <div>{{dogName}} {{dogAge}}</div>
        <h3>mapGetters</h3>
        <div>{{catDesc}}</div>
        <div>{{dogDesc}}</div>
        <h3>mapMutations</h3>
        <button @click="catIncrement({num:1})">猫变化</button>
        <button @click="dogIncrement({num:1})">狗变化</button>
        <h3>mapActions</h3>
        <button @click="catGrow({num:1})">猫动作</button>
        <button @click="dogGrow({num:1})">狗动作</button>
      </div>
    </template>
    
    <script>
    import { mapState, mapGetters, mapMutations, mapActions } from "vuex";
    
    export default {
      name: "HelloWorld",
      computed: {
        ...mapState("cat", {
          catName: "name",
          catAge: "age"
        }),
        ...mapState("dog", {
          dogName: "name",
          dogAge: "age"
        }),
        ...mapGetters("cat", {
          catDesc: "desc"
        }),
        ...mapGetters("dog", {
          dogDesc: "desc"
        })
      },
      methods: {
        ...mapMutations("cat", { catIncrement: "increment" }),
        ...mapMutations("dog", { dogIncrement: "increment" }),
        ...mapActions("cat", { catGrow: "grow" }),
        ...mapActions("dog", { dogGrow: "grow" })
      }
    };
    </script>
    
    <!-- Add "scoped" attribute to limit CSS to this component only -->
    <style scoped lang="scss">
    </style>
    复制代码

    七 运行效果

    原文:https://www.cnblogs.com/sea-breeze/p/11321961.html

    Vuex官网:https://vuex.vuejs.org/zh/guide/modules.html

  • 相关阅读:
    已知: 每个飞机只有一个油箱, 飞机之间可以相互加油(注意是相互,没有加油机) 一箱油可供一架飞机绕地球飞半圈,问题:为使至少一架飞机绕地球一圈回到起飞时的飞机
    简易vector的实现
    简单的内存池实现
    归并排序,递归与非递归
    堆排序
    位运算
    二叉树的建立,以及非递归遍历
    “云端融合”思想的自我摸索(很不靠谱)
    linux android开发环境搭建
    Android系统架构及内核简介
  • 原文地址:https://www.cnblogs.com/itgezhu/p/11989781.html
Copyright © 2020-2023  润新知