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

uniapp和VueI18n多语言H5项目语言国际化功能搭建流程

uniapp多语言项目国家化功能搭建流程

说明:uniapp多语言项目功能搭建分为应用部分框架部分

  • 应用部分,即开发者自己的代码里涉及的界面部分的语言翻译。
  • 框架部分,即uni-app内置组件和API涉及界面的部分的语言翻译。

功能的搭建是需要uniapp内置语言api和VueI18n的相互配合的。

第一步:应用部分多语言功能搭建

  1. main.js 引入并初始化 VueI18n
import en from './en.json'
import zhHans from './zh-Hans.json'
import zhHant from './zh-Hant.json'
const messages = {en,'zh-Hans': zhHans,'zh-Hant': zhHant
}let i18nConfig = {locale: uni.getLocale(),// 获取已设置的语言messages
}
// 以上部分可以单独放入新建local/index.js文件内,记得用export default导出文件内容。// VUE2
// #ifndef VUE3
import Vue from 'vue'
import VueI18n from 'vue-i18n'// v8.x
Vue.use(VueI18n)
const i18n = new VueI18n(i18nConfig)
Vue.config.productionTip = false
App.mpType = 'app'
const app = new Vue({i18n,...App
})
app.$mount()
// #endif// VUE3
// #ifdef VUE3
import { createSSRApp } from 'vue'
import { createI18n } from 'vue-i18n'// v9.x
const i18n = createI18n(i18nConfig)
export function createApp() {const app = createSSRApp(App)app.use(i18n)return {app}
}
// #endif
  1. 新建对应的多语言文件
    举例:en.json
{"index.title": "Hello i18n"
}
  1. 页面模板中使用 t ( ) 获取,并传递国际化 j s o n 文件中定义的 k e y , j s 中使用 t h i s . t() 获取,并传递国际化json文件中定义的key,js中使用 this. t()获取,并传递国际化json文件中定义的keyjs中使用this.t(‘’)
<template><view class="container"><view class="title">{{$t('index.title')}}</view></view>
</template><script>export default {data() {return {}}}
</script>

注意:页面中设置语言后需要调用 this.$i18n.locale = ‘zh-Hans’ 后生效

  1. pages.json 国际化
{"pages": [{"path": "pages/index/index","style": {"navigationBarTitleText": "%index.title%"}}],"tabBar": {"list": [{"pagePath": "pages/index/index","text": "%index.home%"}]}
}

注意:locale目录下 语言地区代码.json 文件中定义的 key,使用 %% 占位

语言文件示例(zh-Hans.json)

{"app.name": "Hello uni-app","index.title": "首页"
}

第二步:框架部分多语言功能搭建

说明:uni-app 有内置的基础组件,比如picker,或者与界面相关的API,比如showModal。这些界面包含的文字也需要国际化。

框架部分可分为自动策略和自定义方案

  1. 自动策略可自动适配手机和浏览器语言

内置语言如下:

  • 中文简体
  • 中文繁体
  • 英语
  • 法语
  • 西班牙语

注意:内置组件和接口显示会根据系统语言环境自动切换,未支持的系统语言环境会显示为英文。

  1. 自定义方案

如果自动适配语言不满足你的需求,比如需要预置的5种语言外的更多语言。那么可以使用自定义方案。在指定目录创建指定文件,用同名词条来替换,语言地区代码请遵循 BCP47 规范。

符合 BCP47 规范 的语言代码
语言代码通常为两个或三个字母,参考链接: ISO 639规范
语言代码-地区代码,地区代码为两个字母,参考链接: ISO 3166-2规范

项目根目录支持 locale 目录,locale/uni-app.语言地区代码.json,如:uni-app.en.json,uni-app.zh-Hans.json,uni-app.zh-Hant.json
举例: uni-app.zh-Hans.json 文件

{"common": {"uni.app.quit": "再按一次退出应用","uni.async.error": "连接服务器超时,点击屏幕重试","uni.showActionSheet.cancel": "取消","uni.showToast.unpaired": "请注意 showToast 与 hideToast 必须配对使用","uni.showLoading.unpaired": "请注意 showLoading 与 hideLoading 必须配对使用","uni.showModal.cancel": "取消","uni.showModal.confirm": "确定","uni.chooseImage.cancel": "取消","uni.chooseImage.sourceType.album": "从相册选择","uni.chooseImage.sourceType.camera": "拍摄","uni.chooseVideo.cancel": "取消","uni.chooseVideo.sourceType.album": "从相册选择","uni.chooseVideo.sourceType.camera": "拍摄","uni.previewImage.cancel": "取消","uni.previewImage.button.save": "保存图像","uni.previewImage.save.success": "保存图像到相册成功","uni.previewImage.save.fail": "保存图像到相册失败","uni.setClipboardData.success": "内容已复制","uni.scanCode.title": "扫码","uni.scanCode.album": "相册","uni.scanCode.fail": "识别失败","uni.scanCode.flash.on": "轻触照亮","uni.scanCode.flash.off": "轻触关闭","uni.startSoterAuthentication.authContent": "指纹识别中...","uni.picker.done": "完成","uni.picker.cancel": "取消","uni.video.danmu": "弹幕","uni.video.volume": "音量","uni.button.feedback.title": "问题反馈","uni.button.feedback.send": "发送"},"ios": {},"android": {}
}

注意:uni-app.zh-Hans.json和zh-Hans.json的命名要一样,否则uniapp识别调用不到。

manifest.json 国际化

{"name" : "%app.name%","appid" : "","description" : "","versionName" : "1.0.0","versionCode" : "100","locale": "zh-Hans" // 设置默认语言,
}

manifest.json 中支持配置应用默认语言,参见上面的示例,"locale"默认为auto,跟随系统OS的语言。

uni-app内置了一批与国际化相关的API和生命周期。链接在这里: uni-app国际化相关的API和生命周期

第三步:调用多语言功能

在设置多语言功能页面加入设置多语言的代码即可,参考如下:

onLoad(options) {let systemInfo = uni.getSystemInfoSync();this.applicationLocale = uni.getLocale();this.isAndroid = systemInfo.platform.toLowerCase() === 'android';uni.onLocaleChange((e) => {this.applicationLocale = e.locale;})
},
methods: {onLocaleChange(e) {if (this.isAndroid) {uni.showModal({content: this.$t('index.language-change-confirm'),  // "index.language-change-confirm": "应用此设置将重启App"success: (res) => {if (res.confirm) {uni.setLocale(e.code);}}})} else {uni.setLocale(e.code);this.$i18n.locale = e.code;uni.setStorageSync('lang', e.lang);window.location.href ="/"}},
}

以上就是我搭建uniappH5项目国际化功能的流程,欢迎各位朋友交流探讨。

http://www.lryc.cn/news/91060.html

相关文章:

  • C# | 凸包算法之Jarvis,寻找一组点的边界/轮廓
  • SpringBoot接收请求参数的方式
  • MKS SERVO4257D 闭环步进电机_系列5 CAN指令说明
  • 安捷伦E4440A(Agilent) e4440a 3HZ-26.5G频谱分析仪
  • 华为OD机试真题 Java 实现【最长子字符串的长度】【2022Q4 100分】,附详细解题思路
  • 【iOS】--对象的底层结构
  • 高并发内存池设计_内存池
  • 给编程初学者的一封信
  • 【无功优化】基于改进教与学算法的配电网无功优化【IEEE33节点】(Matlab代码时候)
  • 数据在内存中的存储(超详细讲解)
  • log4cplus使用示例
  • 人工智能学习07--pytorch20--目标检测:COCO数据集介绍+pycocotools简单使用
  • learnOpenGL-深度测试
  • 阿里云服务器数据盘是什么?系统盘和数据盘区别
  • linux常用命令精选
  • 人体行为足力特征分析及其应用研究_kaic
  • javascript基础二十七:说说 JavaScript 数字精度丢失的问题,解决方案?
  • 重塑工作场所:后疫情时代组织韧性的8个策略
  • TCP协议为什么要三次握手而不是两次?
  • 使用Vuex进行状态管理
  • 【优化调度】基于改进遗传算法的公交车调度排班优化的研究与实现(Matlab代码实现)
  • IMX6ULL裸机篇之I2C实验-硬件原理图
  • 华为OD机试真题 Java 实现【获取字符串中连续出现次数第k多的字母的次数】【2023Q1 100分】,附详细解题思路
  • 充分统计量和因子分解定理
  • M1 PD安装arm ubuntu及Docker
  • TCP协议的RST标志
  • 【软件质量与软件测试 白盒测试与黑盒测试】
  • JavaScript教程(高级)
  • C++进阶 —— 范围for(C++11新特性)
  • ELK +Filebeat日志分析系统