Error in mounted hook: "TypeError: Cannot read properties of undefined (reading '$on')"
时间: 2023-10-17 14:27:19 浏览: 239
错误信息 "Error in mounted hook: "TypeError: Cannot read properties of undefined (reading '$on')" 意味着在 mounted 生命周期钩子函数中,尝试读取未定义属性 '$on' 导致了类型错误。这通常是因为在调用 $on 方法之前,没有正确初始化 Vue 实例或事件总线。
根据引用的描述,这个错误可能是由于初始化太快导致的。在你的代码中,你尝试在数据渲染之前调用了 $on 方法。解决这个问题的一种方法是确保在调用 $on 方法之前,Vue 实例已经完全初始化。你可以在组件的 created 生命周期钩子函数中调用 $on 方法,而不是在 mounted 生命周期钩子函数中。
此外,引用提供了另一个解决该问题的方式。通过在 main.js 中添加以下代码,你可以将事件总线(event Bus)添加到 Vue 实例的原型上:
Vue.prototype.$bus = new Vue()
然后,你可以在组件中使用 $bus 来进行组件间的通信。在你的情况下,你可以使用 $bus.$on 方法来监听事件,并在合适的生命周期钩子函数中调用它。
总的来说,要解决 "Error in mounted hook: "TypeError: Cannot read properties of undefined (reading '$on')" 错误,你可以采取以下步骤:
1. 确保在使用 $on 方法之前,Vue 实例已经完全初始化。
2. 可以考虑在 created 生命周期钩子函数中调用 $on 方法。
3. 或者,你可以通过在 main.js 中添加 Vue.prototype.$bus = new Vue(),来使用事件总线进行组件间的通信,并在合适的生命周期钩子函数中使用 $bus.$on 方法。
希望这些解决方案能够帮助你解决问题。<span class="em">1</span><span class="em">2</span>
#### 引用[.reference_title]
- *1* [Error in mounted hook: “TypeError: Cannot read properties of undefined (reading ‘split‘)](https://blog.csdn.net/m0_61480985/article/details/131664382)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
- *2* [[Vue warn]: Error in mounted hook: “TypeError: Cannot read properties of undefined (reading ‘$on...](https://blog.csdn.net/qq_45803094/article/details/126476879)[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^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文