当前位置: 首页 > news >正文

uniapp使用vue-i18n国际化多国语言

前言:uniapp是自带有i18n这个插件的,如果没有npm安装即可

此插件需要自己去给每一个需要国际化的字符去手动配置key,所以如果是已经完成的项目可能工作量就稍微有点大了

 第一步:

语言命名是有规范的不能乱取名,具体可以参考国际语言代码

在根目录创建locale文件夹用来存放你需要用到的语言包

zh-Hans.json---中文简体语言包,

zh-Hant.json---中文繁体语言包,

en.json---英文语言包,

es.json---西班牙语语言包,

index.js存放相关方法

 index.js

注意:new实例的时候在这里面new比较好,不要去什么main.js里面new然后再挂载,因为在国家化的过程中,有很大概率在外部js中也有文字需要国际化,这时就没办法在外部js访问到国际化实例了

import en from './en.json'//英语语言包
import zhHans from './zh-Hans.json' // 中文简体
import zhHant from './zh-Hant.json' // 中文繁体
import es from './es.json' // 西班牙语言包
import Vue from 'vue'
import VueI18n from 'vue-i18n'
Vue.use(VueI18n)const lang = uni.getStorageSync('language') || 'en';//获取缓存中的语言
// VueI18n构造函数所需要的配置
const i18nConfig = {locale: lang,//当前语言// 所需要用的语言包messages:{en,'zh-Hans': zhHans,'zh-Hant': zhHant,es}
}
const i18n = new VueI18n(i18nConfig)
export default i18n

json包示例:

如tabBar.home为首页tabbar对应的key,key后面的值代表当前的语言环境文字,中文环境下为“首页”,英文环境下为home,

注意:命名规则

key值必须要是唯一的,key值可以是中文,但是尽量不要这么做,

json可以多层对象形式,使用的时候可以通过.key来获取

key命名的时候尽量语义化一点

中文:                                                                英文

第二步:

将i18n引入到main.js,然后传给Vue实例来保证在任何页面都可以快速访问到i18n实例

import i18n from './locale/index.js'
const app = new Vue({...App,i18n,//})

第三步:切换语言

此处主要用到两个方法:uni.setLocale(),this.$i18n.locale 

uni.setLocale()用来切换系统或应用语言环境,调用此方法后会重启整个应用

this.$i18n.locale 用来切换实际语言

注意:uni.setLocale()方法需要在this.$i18n.locale切换语言之后再调用,否则app端会有问题,语言切换不能实时显示

此处因为外部js有点问题,所以切换语言后强制刷新了一下页面,实际无需刷新页面的

			changeLanguage(){uni.showActionSheet({itemList: [// this.$t('public.en'),// this.$t('public.zh-Hans'),// this.$t('public.es'),'English','中文简体','Español',// '中文繁体'],success:  (res)=>{//#ifdef  H5this.$router.go(0);//刷新页面,不然validate.js不好国际化//#endif//#ifdef  APP-PLUSuni.navigateTo({url: '/pages/user/Login/index' // 要刷新的页面路径});//#endifconst language = [{text:'英文',code:'en'},{text:'中文简体',code:'zh-Hans'},{text:'西班牙语',code:'es'},// {text:'中文繁体',code:'zh-Hant'},]this.curLanguage = language[res.tapIndex].text;this.$store.commit('changeLanguage',language[res.tapIndex].code);uni.setStorage({key:'language',data:language[res.tapIndex].code})this.$i18n.locale = language[res.tapIndex].codeuni.setLocale(language[res.tapIndex].code)//切换语言环境必须在this.$i18n.locale之后,否则app端会有意想不到的bug},fail: function (res) {}});},

第四部:使用

页面使用:直接用过$t()传入对应的json文件对应的key替换文字

<view class="item" :class="current === index ? 'on' : ''" v-for="(item, index) in navList"@click="navTap(index)" :key="index">{{ $t('Login.type-login') }}</view></view>

js使用:加个this

data里面使用:this.$t(),如果不生效可以将此值写入计算属性然后return出去,对于data里面的数组可以把文字换成对应的key,然后在html中{{$t(item.name)}}

外部js使用:导入import i18n from '@/locale/index',然后i18n.t()传入key,外部js不要加$符号

tabbar及页面顶部文字:%key%,用%包裹key值即可

第五步: 设置语言类型持久化及默认

 主要是在设置语言的时候将当前的语言类型放入缓存,然后在加载的时候获取缓存里面的语言再设置语言即可,可以在应用的默认加载页面或者整个应用的onLoad里面写

		onLoad() {const  lang = uni.getStorageSync('language')|| 'en';//获取缓存的语言设置this.$i18n.locale = lang//设置语言uni.setLocale(lang);//设置语言环境this.$store.commit('changeLanguage',lang);// 监听语言的切换uni.onLocaleChange(e=>{this.$store.commit('changeLanguage',e.locale);});},

相关文章:

  • 记录 | CUDA编程中使用#ifdef指令控制生成CPU和GPU代码
  • [足式机器人]Part2 Dr. CAN学习笔记-数学基础Ch0-3线性化Linearization
  • CoreDNS实战(九)-性能压测
  • IDEA连接Redis注意事项
  • Arduino项目式编程教学第三章——红外遥控灯
  • CSS单位vmin、vmax
  • 【JMeter】BeanShell了解基础知识
  • C/C++---------------LeetCode第118. 杨辉三角
  • RT-Thread Studio文件消失不见或被排除构建
  • 【唐山海德教育】职称评审需要什么条件呢?
  • 2-- 简要介绍 Kubernetes
  • 【Python】zip
  • 【Openstack Train安装】五、Memcached/Etcd安装
  • 【工作生活】汽车电子嵌入式开发简介
  • python socket编程7 - 使用PyQt6 开发UI界面新增实现UDP server和client单机通讯的例子
  • 【Leetcode】104. 二叉树的最大深度
  • 10个确保微服务与容器安全的最佳实践
  • Android Studio:GIT提交项目到远程仓库
  • eclipse的离线汉化
  • extjs4学习之配置
  • JS基础之数据类型、对象、原型、原型链、继承
  • js继承的实现方法
  • js中的正则表达式入门
  • k8s 面向应用开发者的基础命令
  • Laravel 菜鸟晋级之路
  • mac修复ab及siege安装
  • Mysql数据库的条件查询语句
  • Sass 快速入门教程
  • SpringBoot 实战 (三) | 配置文件详解
  • TypeScript实现数据结构(一)栈,队列,链表
  • uva 10370 Above Average
  • 百度小程序遇到的问题
  • 基于axios的vue插件,让http请求更简单
  • 聊聊redis的数据结构的应用
  • 如何使用 OAuth 2.0 将 LinkedIn 集成入 iOS 应用
  • 入手阿里云新服务器的部署NODE
  • 使用Tinker来调试Laravel应用程序的数据以及使用Tinker一些总结
  • 数据仓库的几种建模方法
  • 腾讯视频格式如何转换成mp4 将下载的qlv文件转换成mp4的方法
  • 小程序、APP Store 需要的 SSL 证书是个什么东西?
  • - 转 Ext2.0 form使用实例
  • ​如何使用ArcGIS Pro制作渐变河流效果
  • ​水经微图Web1.5.0版即将上线
  • #1015 : KMP算法
  • #git 撤消对文件的更改
  • #NOIP 2014#day.2 T1 无限网络发射器选址
  • (个人笔记质量不佳)SQL 左连接、右连接、内连接的区别
  • (六)Hibernate的二级缓存
  • (三十五)大数据实战——Superset可视化平台搭建
  • (已解决)什么是vue导航守卫
  • (原創) 是否该学PetShop将Model和BLL分开? (.NET) (N-Tier) (PetShop) (OO)
  • (转)VC++中ondraw在什么时候调用的
  • .NET CLR基本术语
  • .NET Core 和 .NET Framework 中的 MEF2
  • .Net MVC4 上传大文件,并保存表单