国际化如何在JavaScript中起作用?


143

我想知道如何在JavaScript中处理国际化。我用谷歌搜索,但没有得到令人信服的答案:

  • JavaScript是否具有对国际化的本地支持?
  • JavaScript中的i18n是什么?
  • 如何处理日历,货币,日期等?

我已经阅读过JavaScript中的Internationalization


微软最近发布了一个jQuery全球化插件。详细信息在这里
Adeel

Answers:


161

旧版浏览器中的本地化支持很差。最初,这是由于ECMAScript语言规范中的短语如下所示:

Number.prototype.toLocaleString()
生成一个字符串值,该字符串值表示根据主机环境当前语言环境的约定格式化的Number的值。此函数与实现有关,并且允许但不鼓励这样做,因为它返回与toString相同的东西。

规范中定义的每种本地化方法都被定义为“依赖于实现”,这会导致很多不一致之处。在这种情况下,Chrome Opera和Safari将返回与相同的结果.toString()。Firefox和IE将返回语言环境格式的字符串,并且IE甚至包括一千个分隔符(对于货币字符串而言是完美的)。Chrome最近进行了更新,以返回以千位分隔的字符串,但没有固定的十进制数。

对于现代环境ECMAScript国际化API规范是对ECMAScript语言规范的补充,它是一个新标准,为字符串比较,数字格式以及日期和时间格式提供了更好的支持。它还修复了语言规范中的相应功能。可以在这里找到简介。可用的实现方式:

  • 镀铬24
  • 火狐29
  • Internet Explorer 11
  • 歌剧15

还有一个兼容性实现Intl.js,它将在尚不存在的环境中提供该API。

由于没有用于获取当前语言的规范,因此确定用户的首选语言仍然是一个问题。每个浏览器都实现一种获取语言字符串的方法,但这可以基于用户的操作系统语言或仅基于浏览器的语言:

// navigator.userLanguage for IE, navigator.language for others
var lang = navigator.language || navigator.userLanguage;

一个好的解决方法是将Accept-Language标头从服务器转储到客户端。如果将其格式化为JavaScript,则可以将其传递给Internationalization API构造函数,该构造函数将自动选择最佳(或最先支持)的语言环境。

简而言之,您必须自己做很多工作,或者使用框架/库,因为您不能依靠浏览器来完成它。

用于本地化的各种库和插件:

  • 其他:

随时添加/编辑。


13
感谢所有人的贡献;我从未想过我可以通过阅读旧答案来学到一些东西。我很高兴看到国际化API规范的更新,这真是太棒了,我只需要在Chrome中对其进行测试即可。
Andy E

1
感谢您的出色汇编。从积极的方面看,Mozilla可能很快会发布现代的toLocaleString()-可能为FF28:bugzilla.mozilla.org/show_bug.cgi?
Chris Adams

1
i18next.com现在带有基于locize.com建立的翻译管理-如果您需要解决完整的翻译过程,这可能是一个巨大的胜利-不仅仅是为i18n编写代码。Plus还有一个不错的Incontext编辑器功能...
jamuhl

12

Mozilla最近发布了很棒的L20n或本地化2.0。用他们自己的话说L20n是

一种开放源代码,特定于本地化的脚本语言,用于处理性别,复数形式,共轭形式以及自然语言的其他大多数古怪元素。

他们的js实现位于github L20n存储库上。


我已经开始了一个需要本地化的项目,我们也决定使用L20n;)。因此,在您使用RequireJS的情况下,我已经编写了用于RequireJS的L20n插件的第一个版本(github.com/fernandogmar/L20n-RequireJS),我希望它也对您有用。任何建议都将受到欢迎。
Fernando Gm

0

其中一些是本地的,其余的可以通过库获得。

例如Datejs是一个很好的国际日期库。

其余的只是语言翻译,而JavaScript本机兼容Unicode(以及所有主流浏览器)。


By using our site, you acknowledge that you have read and understand our Cookie Policy and Privacy Policy.
Licensed under cc by-sa 3.0 with attribution required.