vue项目:Cannot read property '_t' of null报错

本文详细解析了在Vue项目中使用vue-i18n插件进行多语言国际化配置时遇到的Cannotreadproperty'_t'ofnull错误,并提供了解决方案。通过调整多语言配置和页面加载顺序,确保在页面跳转前完成多语言资源的加载。

    在使用vue开发一个windows app项目时,遇到Cannot read property '_t' of null的报错,报错的地方是使用this.$message接口在app界面弹出提示框,由于采用中英文的语言国际化,出错之前使用vue.$t("xxx.xx")来获取中英文的提示语(该使用方法可以参考我之前引用的另一篇文章《vue-i18n 切换中英文》),用得挺好的,后台不知道啥原因就提示该种错误,一直也没有发现原因。

查阅资料后怀疑如下:

   vue项目中页面路由快速跳转时,vue-18n有一定概率报错Cannot read property '_t' of null。
来回跳转的多个页面都有配置多语言,如html里的{{$t("xxx.xxx")}},data或method里的vue.$t('xxx.xxx')或者this.$t('xxx.xxx')
在第一页面跳转第二时,页面1的多语言还没加载完成但已经跳转到页面2了,就找不到页面1里的this指向了。

解决办法:
多语言配置文件(我的项目是src/renderer下的i18n/i18n.js)

import Vue from 'vue'
import VueI18n from 'vue-i18n'
import locale from 'element-ui/lib/locale';
import zh from './langs/zh'
import en from './langs/en'
import enLocale from 'element-ui/lib/locale/lang/en'
import zhLocale from 'element-ui/lib/locale/lang/zh-CN'


Vue.use(VueI18n)

const messages = {
  en: Object.assign(en, enLocale),
  zh: Object.assign(zh, zhLocale)
}

console.log(messages.zh)

const i18n = new VueI18n({
  locale: localStorage.getItem('locale') || 'zh',
  messages
})


locale.i18n((key, value) => i18n.t(key, value)) //为了实现element插件的多语言切换

export default i18n

配置多语言的单页面里单独引入i18n,代码如下:
页面里 的this.$t('xxx.xxx')或者vue.$t("xxx.xxx") 改成 i18n.t('xxx'),注意修改后不在需要$符号!!!

import i18n from '@/i18n/i18n'
### 关于 `TypeError: Cannot read property '__wxsClassChanged' of null` 的错误分析 此错误通常发生在 Vue 或其他前端框架中,当尝试访问某个对象的属性时,该对象本身为 `null` 或未正确定义。以下是可能的原因及其对应的解决方案: #### 1. **Vue 组件生命周期问题** 如果在组件尚未完全初始化之前就试图访问某些依赖项(例如子组件实例),可能会导致此类错误。这通常是由于不恰当的时机调用了相关逻辑。 - 确保任何涉及 DOM 操作或子组件交互的操作都在合适的生命周期钩子函数中执行,比如 `mounted()` 而不是 `created()`[^1]。 ```javascript export default { mounted() { this.$refs.table && console.log(this.$refs.table); // 确保 $refs.table 存在再操作 } } ``` #### 2. **模板绑定问题** 在模板中动态绑定数据时,如果没有正确设置初始值或者条件渲染不当,也可能引发类似的错误。 - 对象解构赋值时需注意默认值设定;对于异步加载的数据源,应先验证其存在性后再进一步处理[^3]。 ```html <template> <div v-if="dataSource"> <!-- 数据已准备好 --> <a-table :columns="columns" :data-source="dataSource"></a-table> </div> </template> <script> export default { data() { return { dataSource: null, columns: [] }; }, created() { setTimeout(() => { this.dataSource = [{ key: '1', name: 'John Brown', age: 32 }]; }, 1000); } }; </script> ``` #### 3. **第三方库兼容性问题** 使用像 Ant Design Vue 这样的 UI 库时,版本之间的差异可能导致一些内部实现细节发生变化,从而引起冲突。 - 查看官方文档确认当前使用的 API 是否有变动,并升级至最新稳定版以获得更好的支持与修复。 #### 4. **上下文丢失** 类似于 UniApp 中提到的情况,在特定场景下(如 Vuex store 方法内)通过箭头函数定义回调可以保持正确的 this 指向避免类似问题发生[^2]。 ```javascript methods:{ handleSelectAll(status){ const that=this; this.selectedRowKeys= status ? allRowKeys.slice():[]; if(!status){ that.clearSelected(); // 使用that代替this } } } ``` 以上是从不同角度出发针对该类错误的一些常见排查方向及修正措施总结。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值