【整理】前端国际化小结

近期在做国际化的改造,做了相应的调研,简单做下项目前端国际化的小结

国际化可以分为前端国际化和后端国际化,也可以是前后端组合的国际化
后端多为spring国际化,这里不做展开,百度一下到处都是

常见型

常见的前端国际化方法步骤如下:(原理)

  1. 定义国际化配置
  2. 根据环境读取配置
  3. 将配置展现在页面上

展开说:

  1. 定义国际化配置:
    定义的方式有多种,多以文件的形式单独保存,如json,js,properties 等,
    并且将配置信息以键值对的形式保存备用
  2. 根据环境读取配置:
    所谓环境说白了就是用户选择的标志,形式如下:
    hash型:#cn; #en; #us
    saerch型:?lan=cn; ?lan=en; ?lan=us
    url/meta型: 163.com/cn/; 163.com/en
    缓存型:缓存形式多为cookie,默认cn,用户重新设定后将缓存更新
  3. 将配置展现在页面上:
    使用三方插件或者自己编写插件将配置信息映射到页面上,
    可以使用,juery.i18n.js 或 react、angular国际化插件等regular暂无插件
    插件的基本原理都是做字典查询键值匹配替换。

    以上三步任意组合都可以完成国际化的任务,只是效率各有不同,可根据项目做自由组合

优缺点

优点

  1. 语言包形式统一管理
  2. 工程较大时节省资源
  3. 对于支持多语言项目复用性强

缺点

  1. 配置文件配置复杂
  2. 以键值对的形式定位容易产生混乱
  3. 可读性差
  4. 后期维护时定位比较负责易出错

不常见型

不常见的方法步骤如下:(原理)

  1. 将国际化配置分散在各个文件中如:

    `<a class=‘i18n‘>登录|登入|Sign in|サインイン|???</a>`
  2. 根据环境确定国际化标记:
    cn:0, tw:1, en:2, jp:3, kr:4
  3. 根据国际化标记显示相应信息
    全局搜索class=i18n的元素,保留相应信息
    

优缺点

优点

  1. 可读性强
  2. 易定位
  3. 配置简单
  4. 内容较少时效率高

缺点

  1. 项目工程量大后会浪费资源
  2. 随着支持的语言种类繁多后不容易维护
  3. 复用性差且耦合度高

极端通用型

使用google翻译插件

https://support.google.com/tr...

适用项目:

内容庞大且不在乎准确性,时效性强,更新频繁,支持世界语言

实例:

阿里国际卖场 https://www.aliexpress.com/

项目结合:

  1. 以异步code形式传递信息的,适合做前端国际化
  2. 同步模板式的项目,可使用后端做国际化,如果想轻后端,也可以做前端国际化或者前后端结合做国际化

两个例子

  1. 普通异步项目:

    **nej/jquery项目**
    如果仅需要支持中文和英文,建议使用第二种形式,如果需要支持多国语言,建议使用第一种形式,code错误码可以添加标记定向到国际版错误信息
  2. 组件式项目:
    **Regular/Angular/React...项目**
    因为数据双向绑定和组件化的特点,可以将国际化版本做在组件里,    通过标记继承控制版本的显示,利用路由系统解析hash值,如:
        ‘#/cn/s1‘ : 中文页面S1
        ‘#/s1‘ : 页面S1
        ‘#/en/s1‘ : 英文页面S1
    

原文地址:https://www.cnblogs.com/homehtml/p/12209027.html

时间: 2024-10-17 02:13:17

【整理】前端国际化小结的相关文章

jQuery之前端国际化jQuery.i18n.properties

jQuery之前端国际化jQuery.i18n.properties jQuery.i18n.properties是一款轻量级的jQuery国际化插件,能实现Web前端的国际化. 国际化英文单词为:Internationalization,又称i18n,“i”为单词的第一个字母,“18”为“i”和“n”之间单词的个数,而“n”代表这个单词的最后一个字母.jQuery.i18n.properties采用.properties文件对JavaScript进行国际化.jQuery.i18n.proper

Web前端国际化之jQuery.i18n.properties

Web前端国际化之jQuery.i18n.properties jQuery.i18n.properties介绍 国际化是如今Web应用程序开发过程中的重要一环,jQuery.i18n.properties是一款轻量级的jQuery国际化插件,能在不正确后端做不论什么更改的条件下,轻松简易的实现Web前端的国际化. 与其它国际化工具相比,jQuery.i18n.properties插件具有简单.易用.高内聚低耦合的特点. 国际化英文单词为:internationalization.又称i18n,

前端国际化

摘要: 国际化是指将页面显示的信息翻译成不同语言,可以根据不同语言开发多个版本,然后根据用户选择的语言显示不同的页面.但是这样需要很高的成本,而且维护起来也很麻烦,一个地方有问题就要修改所有版本.本文主要是分享一种前端国际化解决方法,并且已经应用到自己的项目中. 前端国际化需要将页面HTML.javascript的提示信息.后端返回的信息翻译成对应的语言.如果我们能够将这几个地方的内容提取出来,然后用一个翻译函数,根据不同的参数将内容翻译成不同的语言,这样就达到我们的目的了. 页面国际化: 对于

前端系列——jquery前端国际化解决方案“填坑日记”

前言:最近,新的平台还没有开发完成,原来的老项目又提出了新的需求:系统国际化.如果是前后端完全分离的开发模式,要做国际化,真的太简单了,有现成的解决方案,基于Node构建的时下热门的任何一种技术选型都有成熟的方案,比如: vue + vue-i18n angular + angular-translate react + react-intl 但现在的情况是老的项目并没有使用这类架构.说起国际化,博主几年前就做过,在MVC里面实现国际化有通用的解决方案,主要就是通过资源文件的方式定义多语言.最初

jquery.i18n.properties前端国际化解决方案“填坑日记”

但现在的情况是老的项目并没有使用这类架构.说起国际化,博主几年前就做过,在MVC里面实现国际化有通用的解决方案,主要就是通过资源文件的方式定义多语言.最初接到这个任务,并没有太多顾虑,毕竟这种东西有很成熟的解决方案,实现起来难点不会很大.可当真正动起来手来去实现的时候发现一些问题,这里先介绍下我们老平台的架构:MVC+WebApi,MVC项目负责页面渲染,webapi负责数据接口,是一种很传统的架构方式.国际化主要在MVC端去做就好了,可是由于MVC项目里面使用了大量第三方bootstrap组件

如何优雅的实现前端国际化

今天小编会使用boostrap框架搭建一个配有中英文切换功能的网页,还有就是使用nodejs搭建后台服务,从头实现一个完整的前端国际化开发项目,内容不算很复杂,很适合前端已入门的胖友们. 01 .前端国际化概述 港真,自己刚接到这个需求的时候,也是不知如何下手,毕竟也没经验,后面就找了百度,经过一番探索,最终圆满的完成了任务,下面就把我的经验写下来,有需要的朋友拿去,不谢~~~ 首先我们先来普及一下什么是国际化?国际化这个英文单词为:Internationalization,又称 i18n,"i

【转】i18n实现前端国际化(实例)

源地址:https://www.jianshu.com/p/ea93efef5155 i18n实现前端国际化(实例) 0.1442018.08.27 16:25:10字数 246阅读 10563 在今日的需求中需要利用 i18n 这个框架来实现前端的国家化操作,下图是实现效果: 点击选择框实现网页上语言的切换: 下面开始实现过程: 所需工具:- jquery-3.3.1.js 下载地址:jquery- jquery.i18n.properties.js jquery.i18n.propertie

jQuery之前端国际化jQuery.i18n.properties[转]

http://www.ibm.com/developerworks/cn/web/1305_hezj_jqueryi18n/ jQuery.i18n.properties是一款轻量级的jQuery国际化插件,能实现Web前端的国际化. 国际化英文单词为:Internationalization,又称i18n,“i”为单词的第一个字母,“18”为“i”和“n”之间单词的个数,而“n”代表这个单词的最后一个字母.jQuery.i18n.properties采用.properties文件对JavaSc

Web前端优化小结

一.尽可能的减少http请求数,提高访问速度.这些请求包括html文件.CSS文件.JS文件和图片文件等外部资源.1.可以将多个CSS或JS文件合并 a.合并引入.如:<link  type="text/css"   rel="stylesheet"  href="css/a.css,css/b.css"> //淘宝的服务器技术,目前只有tengine可以支持这种模式. DOS命令:copy a.css+b.css ab.css /b