美文网首页前端Vue专辑
uniapp中使用vue-i18n实现国际化多语言

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

作者: 羽翼的翼 | 来源:发表于2019-11-25 10:58 被阅读0次

最近uniapp的一个项目 需要用到国际化切换 做一个总结

1. 首先看一下目录结构

目录结构.png

2. 准备好vue-i18n的js文件(下方有源码地址)

3. lang 文件夹下面写国际化语言的逻辑

1.将所需要的文件引入(en.js zh.js vue-i18n 等)

  1. 获取设备信息 ,并保存本地
    目的: 是为了知道用户手机用的是什么语言,方便用户一进来看到的就是他设备设置的语言,我这里是将获取到的信息全部保存了(项目中需要),也可以只保存system_info.language
    代码如下(写在lang/index.js文件中):
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

4. 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()

5.项目中引入

uniapp 不支持在取值表达式中直接调方法,因此,$t方法不可用,所以通过计算属性的方式:

<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')  
 }  
},

6.demo地址

https://github.com/menglin1997/changeLang

相关文章

  • uniapp与i18n实现国际化

    参考:uniapp与vue-i18n实现国际化多语言 1. main.js 备注:main.js文件:定义全局函数...

  • 国际化:i18n实现多语言

    如果项目需要多语言的支持,我们需要做国际化 使用 vue-i18n 来实现多语言的界面 安装 关于语言包,我们有几...

  • 前端笔记(12)nuxt js 多语言方案

    使用vue-i18n实现国际化,多语言数据保存在locales文件夹内; 通过URL的params与vuex共同维...

  • uni-app 语言化 Vue-i18n

    说到vue-i18n,我们并不陌生,国际化多语言实现。 1.安装依赖包 2.注入vue实例中,项目中实现调用api...

  • vue实现国际化(vue-i18n)

    使用vue-i18n插件来实现vue项目中的国际化功能 vue-i18n安装 全局使用 vue页面中使用 输出如下...

  • VueJS 使用i18n做国际化切换中英文

    vue-i18n 国际化。 1、安装 2、在main.js中引入并使用 3、创建多语言的文件夹和js文件 我是在s...

  • uniapp中使用vue-i18n实现国际化多语言

    最近uniapp的一个项目 需要用到国际化切换 做一个总结 1. 首先看一下目录结构 2. 准备好vue-i18n...

  • i18n国际化

    vue中如何使用i18n实现国际化 一、前言 项目中需要实现多语言切换,这时候接触到国际化,前端框架无数,其中几种...

  • Element分析(工具篇)——Locale

    说明 element很注重多语言,自己进行了处理,如果存在vue-i18n则使用它,否则使用自己实现的工具。 in...

  • 国际化

    国际化 开始使用 pro 通过 vue-i18n 插件来实现全球化的功能。 在 src/lang/index.js...

网友评论

    本文标题:uniapp中使用vue-i18n实现国际化多语言

    本文链接:https://www.haomeiwen.com/subject/xbsdwctx.html