我有一个网站(Flash)本地化成十几种语言,我想根据用户的浏览器设置自动定义一个默认值,以尽量减少访问内容的步骤。
仅供参考,由于代理限制,我不能使用服务器脚本,所以我猜JavaScript或ActionScript将适合解决这个问题。
问题:
“猜测”用户语言环境的最佳方法是什么? 是否有任何现有的简单类/函数可以帮助我(没有复杂的本地化包)?特别是以一种聪明的方式将所有可能的语言减少到更小的数量(我有的翻译)。 在什么情况下我可以相信这样的解决方案? 还有其他的解决方法或建议吗?
我有一个网站(Flash)本地化成十几种语言,我想根据用户的浏览器设置自动定义一个默认值,以尽量减少访问内容的步骤。
仅供参考,由于代理限制,我不能使用服务器脚本,所以我猜JavaScript或ActionScript将适合解决这个问题。
问题:
“猜测”用户语言环境的最佳方法是什么? 是否有任何现有的简单类/函数可以帮助我(没有复杂的本地化包)?特别是以一种聪明的方式将所有可能的语言减少到更小的数量(我有的翻译)。 在什么情况下我可以相信这样的解决方案? 还有其他的解决方法或建议吗?
当前回答
在Chrome和Firefox 32+上,Navigator。Languages包含一个按照用户偏好顺序排列的区域设置数组,比navigator更准确。然而,为了使它向后兼容(已测试的Chrome / IE / Firefox / Safari),然后使用这个:
function getLang() {
if (navigator.languages != undefined)
return navigator.languages[0];
return navigator.language;
}
其他回答
将其从JavaScript移植来检测浏览器语言偏好
https://stackoverflow.com/a/42649975/1548557
我刚想到这个。它结合了较新的JS解构语法和一些标准操作来检索语言和区域设置。
var [lang, locale] = (
(
(
navigator.userLanguage || navigator.language
).replace(
'-', '_'
)
).toLowerCase()
).split('_');
希望它能帮助到别人
**更新:**我还建议测试这个,并结合其他答案,例如https://stackoverflow.com/a/52112155/1548557,这似乎是一个更健壮的方式来获得语言。我们也有零并集??所以||可能不是最好的方法。我想象这就像
var [lang, locale] = (
(
getBrowserLanguage()
.replace('-', '_')
).toLowerCase()
).split('_');
请注意,我没有强制lang或locale的默认值,而您可以这样做。世界是如此以英语为中心,我选择英语,但我不觉得这对我编码的任何人都有好处。我也没有调用getBrowserLanguage getNavigatorLanguage,这是故意的。也许你用的是导航器,但将来可能会用到其他东西。这确实是一种偏好。无论如何,我希望这仍然有用。
结合浏览器用来存储用户语言的多种方式,你得到这个函数:
const getNavigatorLanguage = () => {
if (navigator.languages && navigator.languages.length) {
return navigator.languages[0];
} else {
return navigator.userLanguage || navigator.language || navigator.browserLanguage || 'en';
}
}
我们首先检查导航器。语言数组的第一个元素。 然后我们得到任意一个导航器。userLanguage或navigator.language。 如果失败,我们得到navigator.browserLanguage。 最后,如果其他方法都失败,我们将其设置为“en”。
下面是性感的俏皮话:
const getNavigatorLanguage = () => (navigator.languages && navigator.languages.length) ? navigator.languages[0] : navigator.userLanguage || navigator.language || navigator.browserLanguage || 'en';
本文建议使用浏览器导航器对象的以下属性:
导航器。语言(Netscape -浏览器本地化) 导航器。browserLanguage(特定于ie的浏览器本地化语言) 导航器。systemLanguage(特定于ie - Windows操作系统-本地化语言) navigator.userLanguage
将这些转换成javascript函数,在大多数情况下,您应该能够猜出正确的语言。确保优雅地降级,所以有一个包含语言选择链接的div,这样如果没有javascript或方法不起作用,用户仍然可以决定。如果它起作用了,就隐藏div。
在客户端执行此操作的唯一问题是,您要么将所有语言提供给客户端,要么必须等到脚本运行并检测到该语言后才能请求正确的版本。也许将最流行的语言版本作为默认设置会激怒最少的人。
编辑:我赞同Ivan的cookie建议,但要确保用户以后可以随时更改语言;不是每个人都喜欢浏览器默认的语言。
您还可以尝试从文档中获取语言,这可能是您的第一个调用端口,然后返回到其他方法,因为人们经常希望他们的JS语言与文档语言匹配。
HTML5:
html querySelector(“”),该文件。“lang”getAttribute ()
遗留问题:
元文件。querySelector(“[http-equiv = content-language)。getAttribute(‘内容’)
没有真正的资源是100%可靠的,因为人们可能只是把它放在错误的语言中。
有一些语言检测库可以让您根据内容确定语言。
我使用了所有的答案,并创建了一个单行解决方案:
const getLanguage = () => navigator.userLanguage || (navigator.languages && navigator.languages.length && navigator.languages[0]) || navigator.language || navigator.browserLanguage || navigator.systemLanguage || 'en';
console.log(getLanguage());