
我在多次节目中都提到,国际化应该早做,在【本文受版权保护】【版权所有,侵权必究】系统设计之初就应该设计好,避免后续需要上转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】国际化时,导致系统大改。那么,对于前端项本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】目而言,国际化都要解决那些问题,具体实施【本文受版权保护】【版权所有,侵权必究】时要考虑那些因素呢?本期聊一聊前端国际化【转载请注明来源】【关注微信公众号:wwwtangshuangnet】问题。
【访问 www.tangshuang.n【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.netet 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。在线收听
网易云音乐:点击播放
本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】转载请注明出处:www.tangshua【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。ng.net喜马拉雅:点击播放
【作者:唐霜】本文版权归作者所有,未经授权不得转载。你还可以在苹果自带的podcast应用中【关注微信公众号:wwwtangshuangnet】【未经授权禁止转载】搜“Robust”找到我们的节目收听。
著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。捐赠支持
求打赏🙇如果你觉得 Ro【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.netbust 这样一档技术类的谈话节目还不错【版权所有,侵权必究】【作者:唐霜】,希望我继续做下去,不妨打赏支持。。
著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】
内容大纲
一、概念
本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。【作者:唐霜】
国际化:产品层面,同一产品,将在不同国家【本文受版权保护】【转载请注明来源】市场推广运营。技术层面,要在一套系统中,【版权所有】唐霜 www.tangshuang.net【本文受版权保护】能够让产品在不同国家运行,同时解决不同国著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】家对产品的不同需要。前端层面,同一套代码【原创不易,请尊重版权】转载请注明出处:www.tangshuang.net能够实现多语言,同时预留不同国家定制的能【转载请注明来源】【版权所有,侵权必究】力。
【本文首发于唐霜的博客】【访问 www.tangshuang.n转载请注明出处:www.tangshuang.net【未经授权禁止转载】et 获取更多精彩内容】
本地化:为不同地区文化的特殊需要在视觉上原创内容,盗版必究。【作者:唐霜】、操作体验上、运营商进行不同呈现。
【原创不易,请尊重版权】【原创内容,转载请注明出处】
关系,国际化是本地化的基础,本地化是产品【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net实现国际化的具体落实。国际化一般是前期工转载请注明出处:www.tangshuang.net【作者:唐霜】作,主要是系统整体层面能够提供本地化的能转载请注明出处:www.tangshuang.net【未经授权禁止转载】力。本地化一般是当产品在具体地区开拓市场本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net时的工作,主要是在前期系统预留的扩展能力转载请注明出处:www.tangshuang.net转载请注明出处:www.tangshuang.net基础上,根据地区文化或特定国情制定看上去【原创不易,请尊重版权】【原创不易,请尊重版权】独特(本质上还是一套系统)的产品。举个例原创内容,盗版必究。本文作者:唐霜,转载请注明出处。子,腾讯有很多出海业务,在产品系统层面,【转载请注明来源】【原创不易,请尊重版权】是提供了实施本地化的能力,但是具体到某个【本文首发于唐霜的博客】【原创内容,转载请注明出处】国家实施时,需要单独靠本地团队根据本地情原创内容,盗版必究。【版权所有】唐霜 www.tangshuang.net况进行深度开发。举个例子,东南亚国家,在【本文首发于唐霜的博客】【访问 www.tangshuang.net 获取更多精彩内容】日期格式、货币符号、颜色喜好上,都和中国【未经授权禁止转载】转载请注明出处:www.tangshuang.net不一样,比如中国人喜欢红色蓝色,但是泰国【转载请注明来源】【原创内容,转载请注明出处】马来西亚地区可能更喜欢绿色,爱尔兰国庆节【版权所有,侵权必究】未经授权,禁止复制转载。也是绿色为主题色,但在中国,绿色显然又是转载请注明出处:www.tangshuang.net著作权归作者所有,禁止商业用途转载。不好的颜色。
本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。
二、前端国际化和本地化
【本文受版权保护】【版权所有,侵权必究】原创内容,盗版必究。
从前端技术层面而言,其实,我们只能解决国【原创内容,转载请注明出处】【作者:唐霜】际化本地化中的部分问题,单纯靠前端,是无【原创内容,转载请注明出处】原创内容,盗版必究。法解决全部问题的,比如不同地区的CDN怎【版权所有】唐霜 www.tangshuang.net【版权所有】唐霜 www.tangshuang.net么去部署,这不是靠单纯前端可以解决的。那【版权所有,侵权必究】转载请注明出处:www.tangshuang.net么,前端可以解决哪些问题呢?实际上,在前转载请注明出处:www.tangshuang.net本文作者:唐霜,转载请注明出处。端实际开发中,你可以简单粗暴这么理解,国【原创内容,转载请注明出处】【原创不易,请尊重版权】际化就是支持多语言,本地化就是支持根据当本文版权归作者所有,未经授权不得转载。著作权归作者所有,禁止商业用途转载。地习惯格式化数字、日期、货币等文本。
【本文受版权保护】【原创内容,转载请注明出处】【转载请注明来源】转载请注明出处:www.tangshua【本文首发于唐霜的博客】【本文受版权保护】ng.net
1. 语言包
【作者:唐霜】【转载请注明来源】
- 怎么写语言包比较好? 【原创内容,转载请注明出处】未经授权,禁止复制转载。原创内容,盗版必究。
- 如何加载语言包比较合理?(同步异步) 原创内容,盗版必究。原创内容,盗版必究。未经授权,禁止复制转载。【未经授权禁止转载】
- 关于语言包工作模式的设想(csv->【转载请注明来源】【原创不易,请尊重版权】;json) 原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】原创内容,盗版必究。
- 语言包中的占位符(插值) 【转载请注明来源】著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshu【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】ang.net
2. 语言切换
未经授权,禁止复制转载。【转载请注明来源】
- 直接通过脚本进行切换,还是通过url跳转著作权归作者所有,禁止商业用途转载。【本文受版权保护】到另一个语言的站点? 转载请注明出处:www.tangshua原创内容,盗版必究。【本文受版权保护】ng.net【原创不易,请尊重版权】【未经授权禁止转载】原创内容,盗版必究。
- 重新渲染问题 【本文受版权保护】【关注微信公众号:wwwtangshua未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。ngnet】【未经授权禁止转载】【版权所有,侵权必究】
- 自动根据浏览器判断语言(html[lan本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】g] navigator.languag未经授权,禁止复制转载。未经授权,禁止复制转载。e || navigator.brows本文作者:唐霜,转载请注明出处。【转载请注明来源】erLanguage) 原创内容,盗版必究。【作者:唐霜】原创内容,盗版必究。
3. 日期/货币/数字分隔符
原创内容,盗版必究。转载请注明出处:www.tangshua未经授权,禁止复制转载。【本文首发于唐霜的博客】ng.net【本文受版权保护】原创内容,盗版必究。
- 902 300 (法国),或 9【未经授权禁止转载】【原创不易,请尊重版权】02.300 (德国),又或者 【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。902,300 (美国) 【版权所有,侵权必究】【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。
- locale 的前半部分表示语言,通常由【本文受版权保护】【关注微信公众号:wwwtangshuangnet】 2 或 3 位小写字母组成,符合 IS本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。O 639 【版权所有,侵权必究】【关注微信公众号:wwwtangshua本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.netngnet】本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshua著作权归作者所有,禁止商业用途转载。【本文首发于唐霜的博客】ng.net
- locale 的后半部分表示地区,由符合著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。 ISO 3166标准的 2 或 3 位【原创不易,请尊重版权】【本文首发于唐霜的博客】大写字母,或符合 UN M.49 【本文首发于唐霜的博客】【转载请注明来源】 标准的 3 位数字组成。 【作者:唐霜】著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。
- 用浏览器内置的Intl接口,不需要自己去原创内容,盗版必究。【本文受版权保护】写一大堆格式化逻辑 本文版权归作者所有,未经授权不得转载。【作者:唐霜】
4. 几种市面上最流行的国际化方案
本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。【访问 www.tangshuang.n【转载请注明来源】本文版权归作者所有,未经授权不得转载。et 获取更多精彩内容】【原创内容,转载请注明出处】
- i18next 【原创不易,请尊重版权】【转载请注明来源】本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshua【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.netng.net
- Intl封装 【关注微信公众号:wwwtangshua本文作者:唐霜,转载请注明出处。【原创不易,请尊重版权】ngnet】【原创不易,请尊重版权】【作者:唐霜】【版权所有】唐霜 www.tangshu未经授权,禁止复制转载。【未经授权禁止转载】ang.net
- vue-i18n 【版权所有】唐霜 www.tangshu【原创不易,请尊重版权】【本文受版权保护】ang.net【本文受版权保护】未经授权,禁止复制转载。
- react-intl, react-i1转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】8next 【未经授权禁止转载】【关注微信公众号:wwwtangshua【作者:唐霜】【作者:唐霜】ngnet】【版权所有,侵权必究】
- angular-translate 转载请注明出处:www.tangshua未经授权,禁止复制转载。未经授权,禁止复制转载。ng.net原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。
三、其他前端国际化问题
【作者:唐霜】著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。
1. React SSR 怎么国际化?
【作者:唐霜】【转载请注明来源】【版权所有,侵权必究】
- 根据请求来源判断访问者当地语言 (Acc【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。ept-Language 或 IP 地址本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.net 获取更多精彩内容】) 原创内容,盗版必究。【关注微信公众号:wwwtangshua著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】ngnet】
2. 普通第三方库怎么国际化?
【关注微信公众号:wwwtangshua【版权所有,侵权必究】【版权所有,侵权必究】ngnet】【本文受版权保护】【原创不易,请尊重版权】
- 静态常量的多语言问题 原创内容,盗版必究。著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】转载请注明出处:www.tangshua转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。ng.net
3. 本地化时区问题(包含夏令时问题)
【版权所有】唐霜 www.tangshu本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。ang.net转载请注明出处:www.tangshua本文作者:唐霜,转载请注明出处。著作权归作者所有,禁止商业用途转载。ng.net未经授权,禁止复制转载。【原创不易,请尊重版权】
- 存储UTC-0+Z,使用时再根据实际使用【转载请注明来源】转载请注明出处:www.tangshuang.net者的时区转回来 【版权所有】唐霜 www.tangshu转载请注明出处:www.tangshuang.net原创内容,盗版必究。ang.net本文作者:唐霜,转载请注明出处。【未经授权禁止转载】
4. CSS 中也可以做国际化
转载请注明出处:www.tangshua【关注微信公众号:wwwtangshuangnet】【访问 www.tangshuang.net 获取更多精彩内容】ng.net【访问 www.tangshuang.n【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。et 获取更多精彩内容】转载请注明出处:www.tangshua著作权归作者所有,禁止商业用途转载。【原创不易,请尊重版权】ng.net原创内容,盗版必究。
- 属性选择器[lang=zh] 【转载请注明来源】【原创不易,请尊重版权】转载请注明出处:www.tangshua著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.netng.net本文版权归作者所有,未经授权不得转载。
- :lang(zh) 伪类 【转载请注明来源】【版权所有】唐霜 www.tangshu【版权所有,侵权必究】【原创内容,转载请注明出处】ang.net【本文受版权保护】【版权所有】唐霜 www.tangshu【本文首发于唐霜的博客】未经授权,禁止复制转载。ang.net
- writing-mode: horizo【转载请注明来源】未经授权,禁止复制转载。ntal-tb(横), vertical未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net-lr(竖从左到右), vertical【未经授权禁止转载】【作者:唐霜】-rl(竖从右到左) 【作者:唐霜】【转载请注明来源】【访问 www.tangshuang.n【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】et 获取更多精彩内容】
- sideways-lr 和 sidewa【访问 www.tangshuang.net 获取更多精彩内容】原创内容,盗版必究。ys-rl 侧转 【版权所有】唐霜 www.tangshu本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshuang.netang.net原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。【未经授权禁止转载】
- text-orientation: te本文作者:唐霜,转载请注明出处。【转载请注明来源】xt-combine-upright 合【原创内容,转载请注明出处】【原创不易,请尊重版权】并字符为一个字符 【作者:唐霜】本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshu【本文受版权保护】【本文受版权保护】ang.net【版权所有】唐霜 www.tangshu【未经授权禁止转载】【版权所有,侵权必究】ang.net
- text-emphasis: dot 着原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】重号 原创内容,盗版必究。【版权所有】唐霜 www.tangshu【版权所有】唐霜 www.tangshuang.net转载请注明出处:www.tangshuang.netang.net
- font-variant-east-as【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】ian 字体变化等等 【本文首发于唐霜的博客】【关注微信公众号:wwwtangshua著作权归作者所有,禁止商业用途转载。【原创不易,请尊重版权】ngnet】【版权所有】唐霜 www.tangshu本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。ang.net【本文首发于唐霜的博客】
- 参考 https://segmentfault【作者:唐霜】【关注微信公众号:wwwtangshuangnet】.com/a/1190000022549【作者:唐霜】未经授权,禁止复制转载。455 这篇文章 【访问 www.tangshuang.n本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。et 获取更多精彩内容】转载请注明出处:www.tangshua【本文受版权保护】转载请注明出处:www.tangshuang.netng.net【版权所有】唐霜 www.tangshu【作者:唐霜】本文版权归作者所有,未经授权不得转载。ang.net【关注微信公众号:wwwtangshua【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。ngnet】
5. 谷歌翻译插件带来的问题
【本文受版权保护】【关注微信公众号:wwwtangshua著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】ngnet】
- 由于谷歌翻译插件会在替换文本时修改标签(【本文首发于唐霜的博客】【原创内容,转载请注明出处】DOM结构)会导致vue、react这种原创内容,盗版必究。【访问 www.tangshuang.net 获取更多精彩内容】基于virtual dom的框架产生问题 著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshu著作权归作者所有,禁止商业用途转载。【访问 www.tangshuang.net 获取更多精彩内容】ang.net【关注微信公众号:wwwtangshua原创内容,盗版必究。【本文首发于唐霜的博客】ngnet】【作者:唐霜】
2020-07-12 4840


