uni-app - - - - -vue3使用i18n配置国际化语言

uni-app - - - - -使用i18n配置国际化语言

  • [1. 安装vue-i18n](#1. 安装vue-i18n)
  • [2. 配置文件](#2. 配置文件)
    • [2.1 创建如下文件](#2.1 创建如下文件)
    • [2.2 文件配置](#2.2 文件配置)
    • [2.3 main文件导入i18n](#2.3 main文件导入i18n)
  • [3. 页面内使用](#3. 页面内使用)
    • [3.1 template内直接使用](#3.1 template内直接使用)
    • [3.2 变量接收使用](#3.2 变量接收使用)

1. 安装vue-i18n

bash 复制代码
npm install vue-i18n --save

2. 配置文件

2.1 创建如下文件

  • locales文件夹里的js文件,对应各个语言的配置

2.2 文件配置

en-US.js

js 复制代码
// 英文配置文件
export default {
	str: 'string',
	obj: {
		key1: 'value1',
		key2: 'value2'
	},
	arr: ['arr1', 'arr2']
}

zh-CN.js

js 复制代码
// 中文配置文件
export default {
	str: '字符串',
	obj: {
		key1: '字段1',
		key2: '字段2'
	},
	arr: ['元素1', '元素2']
}

index.js

js 复制代码
import {
	createI18n
} from "vue-i18n";
import zhCN from "./locales/zh-CN";
import enUS from "./locales/en-US";



const systemInfo = uni.getSystemInfoSync();
console.log(systemInfo);

//uni.showModal({
//	title: '宿主语言',
//	content: systemInfo.hostLanguage
//})

let _lan = systemInfo.hostLanguage || 'zh-CN'; //  获取本地存储 || 根据浏览器语言设置

console.log('当前语言为:', _lan);

const i18n = createI18n({
	fallbackLocale: 'zh-CN',
	legacy: false, // 使用Composition API,这里必须设置为false
	locale: _lan, // 默认使用语言
	globalInjection: true, // 全局注册$t方法
	messages: {
		"zh-CN": zhCN,
		en: enUS,
	},
});

export default i18n;

2.3 main文件导入i18n

html 复制代码
import i18n from "./language";

...

app.use(i18n)

3. 页面内使用

3.1 template内直接使用

注意:对象、数据 使用$tm

html 复制代码
<view>字符串:  {{ $t('str') }} </view>
<view>字符串:  {{ $tm('obj.key1') }} </view>
<view>字符串:  {{ $tm('arr')[0] }} </view>

3.2 变量接收使用

html 复制代码
<view>字符串:  {{ pageStr }} </view>
<view>字符串:  {{ pageObj }} </view>
<view>字符串:  {{ pageArr }} </view>
js 复制代码
import i18n from "/language";


const pageStr = ref(computed(() => i18n.global.t("str")))
const pageObj = ref(computed(() => i18n.global.tm("obj")))
const pageArr = ref(computed(() => i18n.global.tm("arr")))


return {
	pageStr,
	pageObj,
	pageArr
}
相关推荐
不写八个2 小时前
Vue3.0教程004:ref和reactive对比
前端·javascript·vue.js
梅羽落4 小时前
JavaScript_03 超简计算器
前端·javascript
ChinaRainbowSea5 小时前
四.4 Redis 五大数据类型/结构的详细说明/详细使用( zset 有序集合数据类型详解和使用)
java·javascript·数据库·redis·后端·nosql
Easonmax6 小时前
【javaSE】内部类(来自类和对象的补充)
开发语言·javascript·ecmascript
计算机-秋大田8 小时前
基于SpringBoot的假期周边游平台的设计与实现(源码+SQL脚本+LW+部署讲解等)
java·vue.js·spring boot·后端·课程设计
新青年.8 小时前
【uniapp】uniapp使用java线程池
javascript·uni-app
答题卡上的情书8 小时前
uniapp版本升级
前端·javascript·uni-app
向明天乄8 小时前
uniapp 地图添加,删除,编辑标记,在地图中根据屏幕范围中呈现标记
android·java·uni-app
大叔_爱编程9 小时前
wx044基于springboot+vue+uniapp的智慧物业平台小程序
vue.js·spring boot·小程序·uni-app·毕业设计·源码·课程设计
枫叶丹49 小时前
【HarmonyOS之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(三)
开发语言·前端·javascript·华为·harmonyos