开发者问题收集

未捕获的类型错误:Vue 不是构造函数 - Vuex 与 Vue 3

2020-08-24
7716

我正在尝试将 Vuex 与 Vue 3 结合使用。这是我在 main.js 中的代码:

import { createApp } from 'vue';
import App from './App.vue';
import Vuex from 'vuex';

const app = createApp(App);
app.use(Vuex);

const store = new Vuex.Store({
    state: {
        counter: 0
    }
});

app.store(store);
app.mount('#app');

尝试此操作时,我收到以下错误:

Uncaught TypeError: Vue is not a constructor

我尝试使用官方 Vuex 文档中推荐的语法,但这也不起作用。有人知道如何解决这个问题吗?

1个回答

发生此错误的原因是您正在调用 new Vuex.Store ,就像对 Vuex 3 所做的那样。

如果您使用的是 Vue 3 ,则必须通过发出以下命令安装 Vuex 4

# npm
npm install --save vuex@next

# yarn
yarn add vuex@next

然后构建您的商店并将其“注入”到 Vue 实例,如下所示:

import { createStore } from 'vuex';
import { createApp } from 'vue';

const store = createStore({
  state () {
    return {
      count: 1
    }
  }
})

const app = createApp({ /* your root component */ });

app.use(store);

有关更多详细信息,请参阅 Vuex 文档:

适用于 Vue 3 的 Vuex 4

Esteban Borai
2020-11-15