一个项目发展到必定的环境或者一开始就是为多国打造的,就须要考虑国际化了。简单来讲,就是一套页面,多套语言。css
前不久作了一个国际化的项目,基于react
和antd
,里面用到了国际化,使用方式也很简单html
import zhCN from 'antd/lib/locale-provider/zh_CN'; return ( <LocaleProvider locale={zhCN}> <App /> </LocaleProvider> );
而后,页面全部的官方组件都变成了中文(默认是英文)。前端
若是你使用其余工程,也有相应的解决方案,好比vue
vue
+ vue-i18n
angular
+ angular-translate
react
+ react-intl
jquery
+ jquery.i18n.property
具体使用方式能够自行搜索,无非就是看各类api
和配置文件。react
能够说至关成熟了,那么,如何本身实现?jquery
其实原理很简单,这里只讲最基本的原理,不谈框架的特性。web
上面列举这里这么多js
框架,有一个共同的特征,就是都有一个相似语言包的东西。json
zh.json en.json jp.json ...
这个也很好理解,把各类语言独立开来,便于管理和维护。segmentfault
便于测试,咱们把请求的过程去掉了,直接写在一个json
对象里面,以下api
intl.js
var intl = { "zh": { "title": "测试", "content": "这是一个测试" }, "cn": { "title": "test", "content": "this is a test" } }
大概会写一些这样的配置语言,而后经过某种手段把对应的字段设置到相应的位置就能够了。
下面是伪代码
<h2 id="title">测试</h2> <p id="content">这是一个测试</p>
var lang = getGlobalVar('LOCALE')||'zh';//获取语言 var local = intl['lang']; $title.innerHTML = local['title']; $content.innerHTML = local['content'];
上面是一个简单的实现思路,若是是一个简单的静态页面,大能够用这种方式,也不须要引入一些第三方库,而后啃他的api
。
固然,国际化还远不止页面静态文字的简单翻译,还包括本地化服务(时间、货币等等),若是涉及到这些仍是使用现成的库来的快。
除了以上js
的思路,还有没有其余的方法呢?这不是废话吗,若是没有就不会来写这篇文章了。
下面重点来了,如何不借助js
来实现国际化?
实现国际化有两个基本要素
语言配置是指如何设置多语言,也就是说如何把多种语言记录下来,就像前面js
里面的配置文件。
前端配置是指如何根据须要把须要展现的语言显示在页面,好比在中文环境下显示中文,英文环境下显示英文,用户看获得才算数。
乍一看,好像不借助js
根本行不通啊,又要配置文件,又要渲染页面内容,简直无解啊。
css
中有个content
生成属性,通常配合伪类:before
或者:after
来使用。
可能一提到content
,不少人可能就明白了,没错,content
就能够实现内容生成。
那么,试一试?
<!DOCTYPE html> <html lang="en"> <body> <h2 class="title"></h2> <h3 class="paragraph"></h3> <h4 class="summary"></h4> </body> </html>
/**ch**/ html:lang(ch) .title:after{ content: '标题'; } html:lang(ch) .paragraph:after{ content: '段落'; } html:lang(ch) .summary:after{ content: '描述'; } /**en**/ html:lang(en) .title:after{ content: 'title'; } html:lang(en) .paragraph:after{ content: 'paragraph'; } html:lang(en) .summary:after{ content: 'summary'; }
怎么样?是眼前一亮仍是。。很锉?
好吧,我也以为很挫,写起来比较麻烦,不过也是一种思路。
上面的方式确实不怎么样,可是思惟也须要一个渐进的过程
下面用到了使用属性值做为content内容,以前的用纯css实现打星星效果(三)也使用这个特性,你们有兴趣能够回过去看下,这里简单介绍一下用法
<style> span:after{content:attr(a)} </style> <span a="我是A"></span>
这样就能够经过属性值来生成内容。
为何要用属性值呢?
上一种方式以前很差缘由还有一点,就是语义化太差,单独看html
文件彻底不知道是什么内容
<h2 class="title"></h2> <h3 class="paragraph"></h3> <h4 class="summary"></h4>
下面我加点属性
<h2 data-lang-ch="标题" data-lang-en="title"></h2> <h3 data-lang-ch="段落" data-lang-en="paragraph"></h3> <h4 data-lang-ch="描述" data-lang-en="summary"></h4>
这下语义化应该没什么问题了吧,很清楚知道每一个标签的内容
你们应该知道我要作什么了吧,以下
/**ch**/ html:lang(ch) [data-lang-ch]:after{ content: attr(data-lang-ch); } /**en**/ html:lang(en) [data-lang-en]:after{ content: attr(data-lang-en); }
很简单,各自取各自对应的属性便可,须要什么语言直接在html
添加属性便可,也不须要什么js
结合以前讲过的css地址选择器,能够很轻松的实现根据地址栏来适配各类语言
[data-lang-ch]:after, #ch:target~[data-lang-ch]:after{ content: attr(data-lang-ch); } #en:target~[data-lang-en]:after{ content: attr(data-lang-en); }
页面添加一点元素
<body> <div id="ch"></div> <div id="en"></div> <h2 data-lang-ch="标题" data-lang-en="title"></h2> <h3 data-lang-ch="段落" data-lang-en="paragraph"></h3> <h4 data-lang-ch="描述" data-lang-en="summary"></h4> <a href="#ch">中文</a> <a href="#en">英文</a> </body>
下面是demo
以上主要探讨了两种彻底不一样的国际化方式,前一种主流,后一种彻底属于另类,但仍是有用武之地的。若是你的页面不太复杂,彻底能够采起这种方式。
没有了js,速度也快了,视野也开阔了,腰也不酸了,腿也不疼了...
虽然以上跳过js
实现了国际化需求,可是若是说是一些动态内容,好比时间,就无法放在属性里面的,这一部分,就只能经过js
来处理了,实属无奈。。
还有一个就是,若是页面复杂,或者需适配语言太多,那就意味着属性要写不少
<h2 data-lang-ch="标题" data-lang-en="title" data-lang-fr="XXX" data-lang-jp="XXX" data-lang-de="XXX" data-lang-fi="XXX" data-lang-it="XXX" > </h2>
这样就不太友好了,这种状况下就推荐主流的js
解决方式
若是喜欢的文章的话,能够点赞并收藏,多多关注个人博客