旧版浏览器中的本地化支持很差。最初,这是由于ECMAscript语言规范中的短语如下所示:
Number.prototype.toLocaleString()
生成一个字符串值,该字符串值表示根据主机环境当前语言环境的约定格式化的Number的值。此函数与实现有关,并且允许但不鼓励使用,因为它返回与 toString 相同的东西。
规范中定义的每种本地化方法都被定义为“实现相关的”,这会导致很多不一致之处。在这种情况下,Chrome
Opera和Safari将返回与相同的结果
.toString()。Firefox和IE将返回语言环境格式的字符串,并且IE甚至包括数千个分隔符(对于货币字符串而言是完美的)。Chrome最近进行了更新,以返回以千位分隔的字符串,但没有固定的十进制数。
对于现代环境 ,ECMAscript国际化API规范是对ECMAscript语言规范的补充,它是一个新标准,为字符串比较,数字格式以及日期和时间格式提供了更好的支持。它还修复了语言规范中的相应功能。可用的实现方式:
- Chrome 24
- Firefox 29
- Internet Explorer 11
- Opera 15
还有一个兼容性实现Intl.js,它将在尚不存在的环境中提供该API。
确定用户的首选语言仍然是一个问题,因为没有获取当前语言的规范。每个浏览器都实现一种获取语言字符串的方法,但这可以基于用户的操作系统语言或仅基于浏览器的语言:
// navigator.userLanguage for IE, navigator.language for othersvar lang = navigator.language || navigator.userLanguage;
一个好的解决方法是将Accept-Language标头从服务器转储到客户端。如果将其格式化为Javascript,则可以将其传递给InternationalizationAPI构造函数,该构造函数将自动选择最佳(或最先支持)的语言环境。
简而言之,您必须自己做很多工作,或者使用框架/库,因为您不能依靠浏览器来完成它。



