首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在Angular 5中对翻译后的列表进行排序(ngx-translate)

如何在Angular 5中对翻译后的列表进行排序(ngx-translate)
EN

Stack Overflow用户
提问于 2018-04-23 15:30:21
回答 3查看 1.2K关注 0票数 1

假设我有以下简单的html代码(Angular 5,ngx-translate):

代码语言:javascript
复制
<div>
    <div *ngFor="let item of items">
        <div>{{item | translate}}</div>
    </div>
</div>

我通过http-get从后端获取“项目”列表。

我的问题是:如何根据项目的翻译值对项目列表进行排序?

示例:

项目:

代码语言:javascript
复制
[ "lbl_a", "lbl_b", "lbl_c" ]  

有了这些翻译:

代码语言:javascript
复制
{
    "lbl_a": "tree",
    "lbl_b": "zoo",
    "lbl_c": "car"
}

然后我想要显示:

代码语言:javascript
复制
car
tree
zoo

(按字母表排序)

EN

回答 3

Stack Overflow用户

发布于 2018-04-23 15:44:49

您可以创建管道,也可以在获取项目时对其进行排序。

代码语言:javascript
复制
this.service.getTranslatedItems().subscribe(items => {
  this.items = items.sort((a, b) => a.localeCompare(b));
});

用管子

代码语言:javascript
复制
transform(items: string[]) {
  return items.sort((a, b) => a.localeCompare(b));
}

在HTML中(仅限管道)

代码语言:javascript
复制
<div *ngFor="let item of items | yourPipeName">
    <div>{{item | translate}}</div>
</div>
票数 3
EN

Stack Overflow用户

发布于 2018-04-23 15:49:26

你不能使用内置的管道来过滤或者sort data

但是,您可以通过编写自己的管道来实现。只需对数据进行翻译和排序即可。

票数 0
EN

Stack Overflow用户

发布于 2018-04-23 15:54:33

您可以按pipe排序

代码语言:javascript
复制
  <div *ngFor="let item of items | orderBy : 'columnname']"">
        <div>{{item | translate}}</div>
    </div>
票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49975586

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档