2

在我的应用程序中,我可以通过标签本地化大部分字符串,如 l20n.js 文档中所述。但有时我必须本地化动态创建的字符串。像:document.getElementById(id).innerHTML = "some text";

我使用 Polymer 和自定义 Web 组件,因此主要目标是为任何本地化案例创建一个函数。如果我尝试document.l10n.get(string);,我会得到TypeError: document.l10n.get is not a function

最好的方法是什么?在官方文档中找不到解决方案。

4

1 回答 1

1

由于document.l10n是 L20nView类的一个实例,因此您可以将formatValueformatValues方法用于您的用例。有关详细信息,请参阅文档

这两种方法都返回承诺,因此您需要执行以下操作:

document.l10n.formatValue('hello', { who: 'world' }).then(
  hello => document.getElementById(id).textContent = hello
);

您可以分配给textContentinnerHTML。请记住,L20n 允许在翻译中使用 HTML,并且仅在使用声明性data-l10n-id方法时对其进行清理。因此,如果您想手动分配给您,innerHTML您可能需要确保您信任翻译的内容。将来我想添加一个特殊的 API 以使用与声明性方法相同的清理 (bug 1228021 ) 将翻译应用于 DOM 元素。

于 2016-02-25T13:57:59.380 回答