位置: IT常识 - 正文

vue3中使用vue-i18n(ts中使用$t, vue3不用this)(vue3中使用for循环引用多个组件)

编辑:rootadmin
vue3中使用vue-i18n(ts中使用$t, vue3不用this)

推荐整理分享vue3中使用vue-i18n(ts中使用$t, vue3不用this)(vue3中使用for循环引用多个组件),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue3中使用window方法,vue3中使用jsx,vue3中使用jsx,vue3中使用扩展运算符,vue3中使用gis地图,vue3中使用for循环引用多个组件,vue3中使用require,vue3中使用jsx,内容如对您有帮助,希望把文章链接给更多的朋友!

vue项目里多语言工具一直用的vue-i18n。 以前用的 vue2,也没啥大问题,就是配置好之后用t(“你的属性名”)就行,现在用vue3其实本来也没太大变化。 但是配置完之后,在html中用$t()没有问题,显示文案什么的一切正常。而在ts中使用$t()方法报错,后来才发现是我没有设置全局的$t()方法。

vue3中使用vue-i18n(ts中使用$t, vue3不用this)(vue3中使用for循环引用多个组件)

记录一下在vue3中使用vue-i18n的方法:

安装vue-18n配置应用挂载全局方法$t以方便在ts中使用(本次记录的重点)

由于1.2.3.好多人写过了,我就简单的写一下,本次记录的重点是4,因为我发现网上好多博客都只写了$t在html中的使用,但是大都没提到在ts中也可能用到。

安装npm install vue-i18n@next 或 yarn add vue-i18n@next在 src 目录下新建 lang 并新建 index.ts 文件import App from '@/App.vue'import { createApp } from 'vue'import { createI18n } from 'vue-i18n'import enLocale from './en/index';import zhLocale from './zh/index';const messages = { zh: zhLocale, cn: zhLocale, en: enLocale, us: enLocale,}const localLang = navigator.language.split('-')[0];const storageLang = window.localStorage.getItem('locale')?.split('"')[1].split('"')[0].toLocaleLowerCase() || 'en';const c = (storageLang.toLocaleLowerCase() !== 'zh' && storageLang.toLocaleLowerCase() !== 'en') ? 'en' : storageLang;const i18n = createI18n({ globalInjection: true, //全局生效$t locale: c || localLang || 'en', messages, legacy: false,})const app = createApp(App)app.use(i18n)

上图中两个语言包的index.ts中的内容自己根据语言需要写:

export default { nNation: 'Country/Region', pleaseInput: 'Account',}在ts中使用全局方法$timport { getCurrentInstance } from "vue";const { appContext : { config: { globalProperties } } } = getCurrentInstance(); // 这里可以根据需要写个hookconsole.log(globalProperties.$t('pleaseSelectNation'))

在html中的使用就比较正常了:

<span>{{ $t("nation") }}</span>

其实本文算是新手记录一下对于globalProperties的使用,希望对您有所帮助。

本文链接地址:https://www.jiuchutong.com/zhishi/295219.html 转载请保留说明!

上一篇:vue 解决问题:Webpack安装不成功,webpack -v无法正常显示版本号(vue中遇到的问题)

下一篇:【语义分割】数据增强方法(原图与标签同时扩增)(语义分割入门教程)

  • 华为p50是直屏还是曲屏(华为p50是直屏还是曲屏好)

  • 华为手机禁止安装恶意应用在哪里修改呢(华为手机禁止安装应用软件,在哪里设置)

  • b站订阅在哪(b站订阅哪里找)

  • 小米10至尊纪念版搭载多少万的秒充(小米10至尊纪念版摄像头)

  • 手机电池健康怎么恢复(手机 电池 健康)

  • 如何关闭华为充电电池异常(如何关闭华为充电线通知)

  • 能上微信不能打开网页(能上微信不能打开网页win10)

  • 苹果xr外放有杂音(iphonexr外放有杂音)

  • 小米的创始人都有谁?(小米的创始人都走了)

  • 锂电池一般能用多少年(锂电池和铅酸电池哪个好一点)

  • 中移在线是干什么的(中移在线好吗)

  • 苹果官网解锁最快几天(苹果官网申请解锁id)

  • 抖音不喜欢的怎么屏蔽(抖音不喜欢的怎么一直刷到)

  • 手机排线松了怎么修(手机排线松了怎么急救苹果)

  • 任务栏可以改变位置和大小吗(任务栏可以改变其长度吗)

  • 幸运字符为什么会掉(幸运字符为什么发消息不加)

  • 致电和来电的区别(致电啥意思)

  • 天猫积分退货成功后会不会返还(天猫积分退货成功怎么办)

  • 手机怎么看特别关心(手机怎么看特别关心我的人QQ)

  • 微信怎么看朋友圈(微信怎么看朋友圈评论记录)

  • card reader接在主板哪里(card reader sd)

  • bin格式用什么打开手机(bin格式怎么用)

  • 小米8为什么网络那么差(小米8为什么网络不稳定)

  • 华为P30怎么取消华为视频自动续费(华为p30怎么取消免打扰模式)

  • iphone xs max有nfc吗(iPhone XS Max有NFC吗)

  • siri旁白模式是什么(siri开启旁白模式关闭网络)

  • apple store怎么取消自动扣费(applestore怎么取消密码)

  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设 电脑维修 湖南楚通运网络