Vue报错解决[Vue warn]: Error in render: “TypeError: Cannot read property ‘state‘ of undefined“

18 篇文章 1 订阅
3 篇文章 0 订阅

报错

Vue2项目中报错:
[Vue warn]: Error in render: “TypeError: Cannot read property ‘state’ of undefined”
[Vue warn]: Error in mounted hook: “TypeError: Cannot read property ‘dispatch’ of undefined”

在这里插入图片描述

常见原因

这个错误提示通常出现在 Vue 组件中,它尝试读取 Vuex store 的 state 对象,但是该对象没有被定义。这可能是由以下几个原因引起的:

1.Vuex store 模块没有正确导入。可以在 Vue 组件中使用以下代码导入store:

import store from '@/store'

这假设 store.js 文件位于 src/store 目录中。如果store.js 文件位于其他目录中,请相应地更改导入路径。

2.组件没有正确连接到 Vuex store。可以在 Vue 组件中使用以下代码将组件连接到 Vuex store:

import { mapState } from 'vuex'

export default {
  computed: {
    ...mapState(['myState'])
  }
}

这里的 myState 是Vuex store 中定义的状态名称。如果组件中使用其他名称,请相应地更改代码。

3.Vuex store 中没有定义所需的状态。
如果 Vuex store 中没有定义尝试使用的状态,则会出现这个错误。可以在 store.js 文件中使用以下代码定义状态:

const state = {
  myState: null
}

解决方法

反复确认代码后,发现并没有上述问题。所以想着看一下是不是版本问题,打开package.json一看vuex是4版本的。
在这里插入图片描述
这就好解决了:
运行以下命令卸载 Vuex 4:

npm uninstall vuex

运行以下命令安装 Vuex 3:

npm install vuex@3
  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

若年封尘

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值