Vuex不会检测动作或突变,但可以很好地检测Getter

2022-06-29 00:00:00 javascript vue.js vuex

我正在尝试在我的Vue应用中设置Vuex。

app.js

require('./bootstrap');

window.Vue = require('vue').default;

import Vuex from "vuex";
Vue.use(Vuex);
import storeData from "./store";

const store = new Vuex.Store(
   storeData
)

Vue.component('home', require('./components/Home.vue').default);


const app = new Vue({
    el: '#app',
    store
});

store.js

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

Vue.use(Vuex);

export const state = {
    members: [],
};

export const getters = {
    members: state => () => {
        return state.members;
    }
};

export const actions = {
    async getMembers({ commit, state, dispatch }){
        const res = await this.$axios.get('getMembers');
        const { data } = await res;
        commit('setMembers', data);
    }   
};

export const mutations = {
    setMembers(state, members){
        state.members = members;
    },
};

export default new Vuex.Store({
  state,
  getters,
  actions,
  mutations
});

Home.vue

<template>
    <div class="container">
        <div class="row justify-content-center">
            <div class="col-md-8">
                <div class="card">
                    <div class="card-header">Home</div>

                    <div class="card-body">
                        {{ members }}
                    </div>
                </div>
            </div>
        </div>
    </div>
</template>

<script>
import { mapGetters, mapActions, mapMutations } from "vuex";
    export default {
        mounted() {
            this.getMembers();
        },
        computed: {
        ...mapGetters({
            members: 'members'
        })
        },
        methods: {
            ...mapActions({
            getMembers: 'getMembers'
        })
        }
    }
</script>

主页上显示了成员对问题的看法。我在开发人员工具中看到它是一个空数组,如果我将它设置为其他值,它将显示它。然而,如果我试图进行突变,它不会检测到操作或突变。例如,该操作会显示:未知操作类型:getMembers&知道这可能是什么原因吗?


解决方案

使用new Vuex.Store对存储区进行了两次初始化,第二次向构造函数提供了存储区实例,这导致了错误。

从store.js导出的是存储,而不是存储数据。

可以是:

const store = new Vuex.Store({
  state,
  getters,
  actions,
  mutations
});

export default store;

那么很明显,它是从store.js中导出的存储实例。

Vue.use(Vuex)也被调用两次,这可能不会导致问题,除了一个警告,因为Vue插件通常包含防止多次初始化的保护措施。Store.js不需要包含它,在应用程序入口点初始化插件是很常见的。

这是一个潜在的错误:

require('./bootstrap');

window.Vue = require('vue').default;

import Vuex from "vuex";
...

根据规范提升导入,此行为取决于设置,但不应期望此代码将按此顺序进行计算。

需要为:

import './bootstrap';
import Vue from "vue";    
import Vuex from "vuex";
import store from "./store";

window.Vue = Vue;
...

相关文章