focbiz多语言方案

一.前言

以前原生dom时代,没有三大框架的时候。做多语言设计,你能想到怎么做?

1、通过变量直接刷新页面

2、 无非是对页面的dom结构进行标记,然后在遍历替换。

现代单页应用,也可以用前者。

但是我们对体验有更高的要求

1、首先我们需要切换无刷感

2、可以实时注册增减多语言

3、不想应用顶层包裹一个多语言的容器

4、 可以在任意地方注册多语言并全局生效

借助响应式的理念,可以满足产品需求

二.响应式库介绍

@focbiz/loong是inbiz团队打造的一个响应式库,可用于构建现代web架构的全局数据流。

首先安装

css 复制代码
npm i @focbiz/loong

然后定制代理对象

javascript 复制代码
import {loong} from '@focbiz/loong'const state=loong({count:0})

react组件内使用

javascript 复制代码
import {useLoong} from '@focbiz/loong'function Counter() {  const [data,setData] = useLoong(state);  return (    <div>      {data.count}      <button onClick={() => {           setData({count:++data.count})}>+1         }                        </button>     </div>  )}

三.基于响应式框架实现多语方案

有了loong一切都简单了。

1.首先定义多语言,语种标识要尽量参照于国际相关标准

css 复制代码
export const companent = {  'zh-CN': {a: '你好'}, 'en-US': {a: 'hello'}, 'ja': {a:'亚麻'};

2.提供全局多语言对象locales生成一个可以被监听loong对象,这里loong可以用其他库替换

javascript 复制代码
import {loong} from '@focbiz/loong';const locales= {};export const localesHander = loong(locales);

3.提供消费的hooks,根据对象路径进行查找

期间要对传入的 token做必须得校验,和查找。校验是必要的tokenstring格式验证已经存在验证等。查找是根据 token作为对象路径查找

kotlin 复制代码
const useMessage=(key:tokenstring)=>{const [data] = useLoong<typeof locales>(localesHander)   return data[nowLangKey][tokenstring]}

4.组件不做演示,组件就是使用hooks,封装一个基础的react组件即可

5.提供全局注册多语言的方法 mergeLocales方法就是对象的合并

javascript 复制代码
export const registerLocales=(...packages: Locales[])=> {   packages.forEach((locales) =>     mergeLocales(locales, locales)}) }
  1. 最后可以把这些方法挂着window上,可以实时查看以及注册调试等

四.结语

@focbiz/loong可以替换成其他的数据流方案,但是多语言的设计理念是相通的。在设计时要考虑是国际化还是本地化。

因为网页文字的显示往往是翻译即可,使用者能看懂。但是本地化还需要考虑当地的文化习俗,以及用户习惯,同时文字的翻译表达也应该更贴近当地人的日常。

相关推荐
玩电脑的辣条哥2 小时前
Python如何播放本地音乐并在web页面播放
开发语言·前端·python
ew452182 小时前
ElementUI表格表头自定义添加checkbox,点击选中样式不生效
前端·javascript·elementui
suibian52352 小时前
AI时代:前端开发的职业发展路径拓宽
前端·人工智能
画月的亮2 小时前
element-ui 使用过程中遇到的一些问题及解决方法
javascript·vue.js·ui
Moon.92 小时前
el-table的hasChildren不生效?子级没数据还显示箭头号?树形数据无法展开和收缩
前端·vue.js·html
m0_526119402 小时前
点击el-dialog弹框跳到其他页面浏览器的滚动条消失了多了 el-popup-parent--hidden
javascript·vue.js·elementui
垚垚 Securify 前沿站2 小时前
深入了解 AppScan 工具的使用:筑牢 Web 应用安全防线
运维·前端·网络·安全·web安全·系统安全
工业甲酰苯胺5 小时前
Vue3 基础概念与环境搭建
前端·javascript·vue.js
lyj1689975 小时前
el-tree选中数据重组成树
javascript·vue.js·elementui
mosquito_lover16 小时前
怎么把pyqt界面做的像web一样漂亮
前端·python·pyqt