gpt4 book ai didi

angular - ngx-translate 与 ts 文件上的动态文本

转载 作者:太空狗 更新时间:2023-10-29 18:05:13 26 4
gpt4 key购买 nike

我正在使用 ngx-translate用于 Ionic 3 应用程序的国际化。我在 HTML 代码中很好地使用了 pipe。但是现在我在 ts 文件上遇到了如下情况。你能告诉我如何使用 ngx 处理这种动态用例吗?

 updateApi(topic) {
this.showToast(`Topic ${topic.name} subscribed!`);//this is the dynamic text
}

showToast(message) {
let toast = this.toastCtrl.create({
message: message,
duration: 3000
});
toast.present();
}

这里的问题是我不知道 ${topic.name} 的值。那么如何在 i18n json 文件中给出 key/value 呢?还是我在这里遗漏了什么?

最佳答案

你必须在你的组件中注入(inject)翻译服务:

constructor(private translate: TranslateService) {}

并在你的翻译文件中声明如下:

{
"TOPIC": "Topic {{value}} subscribed!"
}

那么您可以选择以下方式之一:

即时翻译:

showToast(this.translate.instant('TOPIC', {value: topic.name}));

用可观察的翻译

this.translate.get('TOPIC', {value: topic.name}).subscribe(res => {
showToast(res);
});

直接在模板中翻译

{{ 'TOPIC' | translate: {value: topic.name} }}

关于angular - ngx-translate 与 ts 文件上的动态文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46155989/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com