Sha*_*ham 5 internationalization angular-i18n angular angular7
简短的问题
我可以有一个输入元素,其中占位符文本会根据组件的状态而变化吗?
更长的问题
Angular 可以通过以下语法示例添加 i18n:
<input i18n-placeholder placeholder="default placeholder" />
Run Code Online (Sandbox Code Playgroud)
它还可以通过以下语法示例添加复数规则:
<span i18n>
Updated {minutes, plural, =0 {just now} =1 {one minute ago} other {{{minutes}} minutes ago}}
</span>
Run Code Online (Sandbox Code Playgroud)
我尝试合并这两个功能,以便占位符的文本根据组件的状态而变化。组件模板包含以下 html:
<input i18n-placeholder placeholder="Add {stuff.length, plural, =0 {} other {more}} stuff..." />
Run Code Online (Sandbox Code Playgroud)
我希望占位符Add stuff...在单数情况下和Add more stuff...复数情况下说,但我在占位符中得到的只是Add.
有没有办法在不复制元素和使用的情况下在 html 属性中获得复数 i18n *ngIf?
这实际上与 i18n 没有太大关系。它仅表明 Angular 似乎无法正确解析和处理属性内的复数表达式。
一个(相对肮脏的)解决方法是简单地将该表达式放在一个不可见的 DOM 节点(例如模板)中,将这个 dom 节点 i18n,并在占位符中插入该 DOM 节点的文本:
<input #myInput [placeholder]="ph.innerText">
<ng-template #ph i18n>Add {stuff.length, plural, =0 {} other {more}} stuff...</ng-template>
Run Code Online (Sandbox Code Playgroud)