最近uniapp的一个项目 须要用到国际化切换 作一个总结vue
1.将所须要的文件引入(en.js zh.js vue-i18n 等) 2. 获取设备信息 ,并保存本地 目的: 是为了知道用户手机用的是什么语言,方便用户一进来看到的就是他设备设置的语言,我这里是将获取到的信息所有保存了(项目中须要),也能够只保存system_info.language
代码以下(写在lang/index.js文件中):git
import LangEn from './en.js'
import LangChs from './zh.js'
import Vue from 'vue'
import VueI18n from './vue-i18n'
Vue.use(VueI18n)
const system_info = uni.getStorageSync('system_info')
if (!system_info) {
// 获取设备信息
uni.getSystemInfo({
success: function (res) {
uni.setStorageSync('system_info', res);
}
})
}
const cur_lang = system_info.language == 'en' ? 'en' : 'zh_CN'
const i18n = new VueI18n({
locale: cur_lang || 'zh_CN', // 默认选择的语言
messages: {
'en': LangEn,
'zh_CN': LangChs
}
})
export default i18n
复制代码
main.js
中引入import Vue from 'vue'
import App from './App'
Vue.config.productionTip = false
App.mpType = 'app'
import i18n from './lang/index'
Vue.prototype._i18n = i18n
const app = new Vue({
i18n,
...App
})
app.$mount()
复制代码
uniapp 不支持在取值表达式中直接调方法,所以,$t方法不可用,因此经过计算属性的方式:github
<template>
<view class="content">
<image class="logo" src="/static/logo.png"></image>
<view class="text-area">
<text>{{ i18n.game }}</text>
</view>
<button type="primary" @tap="change">切换语言</button>
</view>
</template>
复制代码
computed: {
i18n () {
return this.$t('index')
}
},
复制代码