liupangustest

tuya i18n for internationalization

Usage no npm install needed!

<script type="module">
  import liupangustest from 'https://cdn.skypack.dev/liupangustest';
</script>

README

i18n

功能

  • 支持浏览器端和node端的多语言
  • 支持多种语言查询和转换
  • 待写

开始

安装

npm install @tuya-fe/i18n

初始化

init方法进行初始化

例子:

import __ from '@tuya-fe/i18n'

__.init({
    defaultLocale: 'en', // 可选,系统会默认判断语言,若判断失效,显示该设置的默认语言,不设置默认en
    <!-- req,  // node环境必选,用于服务端 HTTP response object of server -->
    headers: '', // node环境下req的headers
    localeUrl, // 必选,查询多语言后台接口URL
}).then(() => {
    // doSomethingOthers
})

使用

1)基本的使用

一、查询

推荐:get方法

例子:

__.get(key)
{
    'TITLE': 涂鸦智能
}
render () {
    return (
        <div>{ __.get['TITLE'] }</div> // 涂鸦智能
    )
}

为了保持兼容旧写法,也可以(不推荐):

__.title

二、切换语言

switch(locale)方法

例子:locale为语系唯一标识,比如 'zh','en'

__.switch('en')

2)包含变量

如下例子,包含变量name,在get方法中注入变量name的值tuya

{'key': 'i love {name}' }
__.get('key', { name: 'tuya' })
// i love tuya

3) 包含复数和数字分隔符等

采用业界通用的ICU Message syntax语法

如下例子,变量name分别为0,1和1000000

{ "key": "I have {num, plural, =0 {no books.} =1 {one photo.} other {# books.}}" }
__.get('key', {num:0}); // "I have no books."
__.get('key', {num:1}); // "I have one book."
__.get('key', {num:1000000}); // "I have 1,000,000 books."

3)货币

语法: { name, type, format }

format可选,若format省略,type为number,则会返回格式化后的数字分隔符

若format是该货币的一种,则会返回相关联的货币格式

例子,变量name为car,type为number以及format为USD

{ "key": "My car is { car, number, USD }" }
__.get('key', { car:123456.78 }); // My car is $123,456.78

方案

语言包缺失提示

1)语言包为空,控制台提示

2)__.get(key),若指定key不存在时,控制台提示

定位语言

  • 1、依据cookie查找语言,若为空,执行第2步
  • 2、根据请求头accept-language权值大小选择语言,若无匹配,显示默认语言
  • 3、待补充

浏览器端缓存策略

采用localForage进行缓存当前环境的多语言

  • 异步存储
  • 离线存储
  • 优雅降级
  • 存储多种类型

localForage 有一个优雅降级策略,若浏览器不支持 IndexedDB 或 WebSQL,则使用 localStorage。

node端存储

redis

语言包发布、变更等处理

根据接口返回的数据版本标识,更新前端数据

缓存被清空、语言包为空和key出错等异常场景

异常场景处理

迁移问题

待确认

遗留问题

待定