位置: 编程技术 - 正文

详解React-Native全球化多语言切换工具库react-native-i18n(react native community)

编辑:rootadmin

推荐整理分享详解React-Native全球化多语言切换工具库react-native-i18n(react native community),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:react-native-elements,react-native-reanimated,react native realm,react-native-elements,react native realm,react-native-fs,react native realm,react-native-reanimated,内容如对您有帮助,希望把文章链接给更多的朋友!

开篇??篓C阶段感悟

最近2 -3个月基本都因为一些私事没怎么系统的工作和学习,途中看了几天Kotlin的东西写了些demo并且整了个小项目,但是整体状态不是很好,这些天看到些后码农的强势细思极恐。

现在大多数醒来就已经是中午,起得早去一下健身房,起的晚就家里宅一天。公司有事或者有其他家事就去协调/沟通/处理下,整个人感觉都提前进入养老状态(当然这个锅有一半是沉迷王者荣耀不可自拔,不太好)

最近项目上基本没啥事情了,然后让手下的小伙伴们对之前做的一些内容进行二次封装,然后他们引用了一个第三方国际化的库我觉得不错,然后看了看源码就分享下,希望大家用得上(虽然现在产品的受众群都是国内的,但是准备下好像没毛病?)

废话??峦炅耍?瞎婢兀?a rel="external nofollow" target="_blank" href=" (虽然我不怎么工作了,但是git还是每天会花时间看看)

库属性介绍:

项目地址: 属性 解释 支持RN版本 所有版本 支持平台 iOS+Android 是否需要NativeModule 是 是否可移植 是 是否含有jni模块 否

使用:

1.install (略,git里都写着了,就是npm那些事)

2.项目中使用

因为是一些静态属性引用,所以你用redux做储存替换也可以,直接做饮用也可以(本文拿en,zh为例)。

首先是建英文版本的配置文件,en/index.js

然后是中文的zh/index.js

属性名,结构是一致的只是属性不同,当然这里是静态的2个文件,如果场景需要可以服务端下发json,那就是完全动态的了,这部分看业务需求了。

2.1 默认的语言环境

我们在上面写了2种语言配置,那么哪种作为初始化的呢?在业务层调用前,我们可以先进行预设

in/index.js

这边进行了一些预设,默认语境为en,允许fallbacks状态(为true时,顺序向下遍历翻译),预设转换的文件就2个,一个en一个zh,这个你也可以自行后续添加根据需求而定。

详解React-Native全球化多语言切换工具库react-native-i18n(react native community)

2.2 业务层调用

先是倒包

import {in} from '你预设的index的目录';

调用(拿一个Toast做个例子)

两种输出结果如下:

源码分析

这个库的实现分为2部分,一部分是Native的版本判断等功能以及js部分的核心实现fnando/in-js

in-js是一个轻量级的js翻译库,他支持各种格式和内容的换算和语言内容的切换,地址如下: In.js做的那么Native做了些啥呢?我们来一探究竟(以安卓为例,苹果看不懂,抱歉)

Native代码就两个类,所以我之前说你直接把Native代码copy走然后项目依赖In.js也能达到这个效果

RNInPackage是一个普通的Package类,它的作用就是把我们的module加到主应用的getPackages()方法中的列表里,然后一起打进包里而已。

具体功能都在RNInModule里

加一个toast看下locale会出现什么

效果如下:

本想一探究竟内部的实现,结果是个不公开的类

总结:

首先Native那里获取本手机的LocaleList然后格式化取第一个元素交由In.js处理,然后In.js根据key选用一套有效的语言规则,再之后流程就和使用时候的顺序一样了。 整个库集成难度较低,使用起来比较简便,使用下来没碰到大坑,配合redux更美味。

标签: react native community

本文链接地址:https://www.jiuchutong.com/biancheng/369717.html 转载请保留说明!

上一篇:js 客户端打印html 并且去掉页眉、页脚的实例(js浏览器打印)

下一篇:React-intl 实现多语言的示例代码(react either)

  • 房屋租赁如何开增值税专用发票
  • 预缴企业所得税计税依据
  • 税务局核定税种是什么意思
  • 农产品普票进项税抵扣怎么做账
  • 金蝶固定资产累计折旧怎么改
  • 个人独资企业500万以下
  • 土地以租代卖,违法吗
  • 自行建造固定资产中的自营工程,在领用工程物资
  • 服装厂委托物资零散加工成品如何做账呢?
  • 违约金没有发票
  • 抵债的货物按什么算增值税
  • 为员工买的人寿保险怎么做账
  • 补交企业所得税怎么填申报表
  • 社保公积金会计分录怎么写
  • 企业间借贷利息规定
  • 增值税发票收款人和复核人可以一个人吗
  • 一般纳税人认定书
  • 发票联给错怎么办?
  • 小规模纳税人税收政策2023
  • 哪些情况下不就地分摊缴纳企业所得税?
  • 未认证进项税额转出
  • 外贸企业支付境外佣金
  • 固定资产清理出售合同
  • 委托销售的增值税税率
  • 海关专用缴款书怎么认证?
  • 银行抵押贷款结清后需要解押吗
  • 工程项目预缴税金
  • 怎么计算房产税率
  • 其他应付款包括应付职工薪酬吗
  • 最新双色球开奖号码
  • 网页无法复制文字破解
  • 笔记本电脑预装
  • 简易征收月末需要转出未交增值税吗
  • 最新制作视频的软件
  • 上个月做无票收入这个月开票,怎么做分录
  • php与mysql基础教程
  • 电脑文件删除如何找到
  • 增值税纳税申报首先要稽核比对
  • thinkphp save
  • phppoem
  • c#openxml
  • php编程基本语法是什么
  • php抽奖程序源码
  • php目录浏览
  • 黏菌算法总结
  • 六自由度机器人简图
  • php使用while循环计算1到100的和
  • ci框架的优缺点
  • upf命令
  • 增值税直接减免税额要交企业所得税吗
  • 后浪是什么意思网络用语
  • 上市公司发行股票会计分录
  • 购进固定资产的进项税计入成本吗
  • 2022年最新电脑操作系统
  • python创建ndarray
  • 纳税申报的流程如何?面试怎么说
  • 子公司再设立子公司
  • 公司归还股东借款是否需要股东会决议
  • 一般纳税人开普票要交税几点
  • 进项税额转出的会计分录怎么做
  • 公司向个人借款合法吗
  • 单位房屋出租收入应交哪些税
  • 小规模发票跨月冲红怎么纳税申报
  • 不交社保如何在网上投诉
  • 水电费收据可以入公司帐吗
  • 研发费用中可以有委托研发核算吗
  • 采用账龄分析法计提坏账准备
  • windowsxpwindows7都是
  • win10预览版怎么安装
  • linux的内存
  • jquery 点击按钮
  • 一个字符串中某个字符串出现的次数
  • css设置表格隔行换色
  • unity增加组件
  • wordpress基于什么语言
  • 国家税务局太原税务局官网
  • 留抵税额可以留抵多久
  • 天津市车船税收费标准2023
  • 青岛税务局局长是什么级别?
  • 什么是党建工作一体化
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设