react native 国际化(多语言)

作者: giants_one | 来源:发表于2018-02-28 09:21 被阅读562次
    5ACF79A333C7F62349D712BC29EC5BA9.jpg
    C8412602F259771C656EF19DD62A93A0.jpg B20051984E994AB1EE5588476BE245B7.jpg
    应留言的要求,我觉得需要花点时间整理一下关于多语言的资料了,献给各位小伙伴希望能带给大家一些思路。由于一些特殊的原因上图项目不好做为开源项目提供给大家,所以我自己写了一个小demo(源码见文尾),废话不多说开始正题。

    准备阶段:

    • react-native-i18n 第三方多语言库
      安装: yarn add react-native-i18n
    • react-native-device-info 用户获取系统本地语言环境
      安装: yarn add react-native-device-info and react-native link react-native-device-info

    实践阶段:

    在项目中创建zh.jsen.jsI18n.js三个js文件,DataRepository.js是一个我自定义的数据持久化类,在这个demo中的作用是存取用户改变后的语言环境,直接拷贝过去就可以用(不是必须的)。

    image.png
    代码分别为:
    zh.js
    export default {
      english: '英文',
      chinese: '中文',
      changeToEnglish: '切换到英文',
      changeToChinese: '切换到中文',
      changeToSystem: '切换到系统语言',
    }
    

    en.js

    export default {
        english: 'english',
        chinese: 'chinese',
        changeToEnglish: 'change to english',
        changeToChinese: 'change to chinese',
        changeToSystem: 'change to System',
    
    }
    

    I18n.js

    import I18n,{ getLanguages } from 'react-native-i18n'
    import DeviceInfo from 'react-native-device-info'
    import DataRepository from '../dao/DataRepository'
    import en from './en'
    import zh from './zh'
    
    
    
    I18n.defaultLocale = 'en';
    
    I18n.fallbacks = true;
    
    I18n.translations = {
        en,
        zh,
    };
    
    I18n.localeLanguage = () => {
    
        new DataRepository().fetchLocalRepository('localLanguage')
            .then((res)=>{
    
                I18n.locale = res;
    
            })
            .catch((error)=>{
    
                I18n.locale = DeviceInfo.getDeviceLocale();
    
            });
    
        return I18n.locale;
    
    };
    
    
    export { I18n, getLanguages };
    

    重点方法、属性讲解

    • I18n.t() : 使用频率是最高的,举个栗子:
    <Text style={styles.welcome}>
                {I18n.t('english')}
            </Text>
    

    以上I18n.t('english')中的english参数就是在zh.jsen.js文件中的语言配置项

    image.png
    image.png
    具体显示内容会随着语言环境调用相应的语言配置文件,呈现给用户相应的语言内容。
    • I18n.getLanguages 获取用户首选的语言环境
    • I18n.locale : 设置本地语言环境。
    • I18n.defaultLocale 首选默认语言
    • I18n.fallbacks : 看文档说明我理解的意思是:如果获取到的系统语言类似en_US en-GB这样的,插件初始化的时候发现没有en_US.js en-GB.js,这个时候如果设置了I18n.fallbacks = true;系统就会按这样的(en_US en.js)顺序去查找文件,就会去找有一个en.js这样的文件, 官方建议使用I18n.fallbacks = true;

    更多关于i18n-js 的属性和方法请 点击这里查看

    ios需要配置语言环境:

    image.png

    使用过程中发现一个刷新的问题:

    我在使用过程中发现调用了I18n.locale=‘我设置的语言’后,当前的界面语言并没有改变,而其他界面的语言已经改变了,就比如说我上面截图的侧滑菜单,当我在侧滑菜单切换语言后发现侧滑菜单里面的语言并没有发现变化,而首页的语言环境已经改变了,我不知道为什么,摸索最后找到了一种解决方案(可能不是最佳方案,但是解决了刷新当前界面语言的问题,如果有更好的方法欢迎👏分享),解决方案:调用一下setState(无论设置的这个state属性在render中有没有被使用,都有效)。 具体代码看App.js,我项目中有使用localeLanguage所以我把改变后的语言存到state

     this.setState({
                localeLanguage: I18n.locale
            });
    
    image.png
    image.png

    demo敬上 GitHubDemo,欢迎 ❤️ 关注 你们的认可是我写作最大的动力,如果有什么错误或者疑问的地方欢迎在评论区留言讨论,我看到后会尽快回复大家。

    相关文章

      网友评论

      • Mar_er:大佬app 名称有做国际化吗
        Mar_er:@giants_one 那最后APP名称有做国际化吗
        giants_one:由于运营问题后来没有上架
      • 云深不知处a:以前也做过国际化的,效果不怎么痒
        giants_one:@a等风 静态的字段都是这么做的,原生做也是类似的做发
        云深不知处a:@giants_one 我的项目写的国际化,一切翻译都要先配置好,太繁琐了
        giants_one:@a等风 效果不怎么样,这句话怎么理解。。
      • 魅璃儿:我在react-navigation,里面设置了i18n.t('tabar.tabPromotion'),语言并没有切换这是是怎么回事?QQ:2922386216
        giants_one:@魅璃儿 我看看你tabar代码
        魅璃儿:你说tabar.tabPromotion的value 么?都是字符串啊!
        giants_one:tabar.tabPromotion是啥?这里是支持String类型的
      • 胖胖她哥Ethan:Good,很强~
        giants_one:@YeXunSzeTo 果酱 果酱
      • 挂着铃铛的兔:很强,可以的
        giants_one:@挂着铃铛的兔 :+1:
        挂着铃铛的兔:@giants_one 后台自己实现了。
        giants_one:@挂着铃铛的兔 我知道你最近想做这块,可以一起讨论 😄
      • 邦邦忙噢:你好厉害
        giants_one:厉害的人大有人在,这几天我花时间写一个demo敬上
      • YanYang6:干嘛不开源
        giants_one:由于一系列不可描述的原因,原项目不好开源,这几天我花时间写一个demo敬上
      • uuuuuuw:有~~~~

      本文标题:react native 国际化(多语言)

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