angular - 如何在 Typescript 或 Angular 中自定义排序 JSON 数组

标签 angular sorting typescript ng-switch

如何在 Angular 中对 JSON 数组进行排序?数组:

{"title":"DEASDFS","Id":11},
{"title":"AASDBSC","Id":2},
{"title":"JDADKL","Id":6},
{"title":"MDASDNO","Id":3},
{"title":"GHFASDI","Id":15},
{"title":"HASDFAI","Id":1},
{"title":"ASDHFI","Id":9},

我想要 Id 的顺序如下:

15,6,1,11,9,2,3

<div *ngFor="let field of fieldsData;let i=index;">
  <div class="form-inline assigned_text-box" [ngSwitch]="field.Id">

    <div class="col-md-2" *ngSwitchCase="15">
      <label>One</label>
    </div>
    <div class="col-md-2" *ngSwitchCase="6">
      <label>Two</label>
    </div>
    <div class="col-md-2" *ngSwitchCase="1">
      <label>Three</label>
    </div>
    <div class="col-md-2" *ngSwitchCase="11">
      <label>Four</label>
    </div>
    <div class="col-md-2" *ngSwitchCase="9">
      <label>Five</label>
    </div>
    <div class="col-md-2" *ngSwitchCase="2">
      <label>Six</label>
    </div>
    <div class="col-md-2" *ngSwitchCase="3">
      <label>Seven</label>
    </div>

  </div>
</div>

但是当我使用 ngSwitch 条件时,首先打印的是哪个 所以它就像 JSON 11,2,6,3,15,1,9

但是我想要这个订单15,6,1,11,9,2,3。我怎样才能实现这个自定义排序数组?

最佳答案

只需使用 Array#sort 对数组进行排序方法。

// reference for sort order priority
const ref = {
  15: 0,
  6: 1,
  1: 2,
  11: 3,
  9: 4,
  2: 5,
  3: 6
};

let data = [{
    "title": "DEASDFS",
    "Id": 11
  },
  {
    "title": "AASDBSC",
    "Id": 2
  },
  {
    "title": "JDADKL",
    "Id": 6
  },
  {
    "title": "MDASDNO",
    "Id": 3
  },
  {
    "title": "GHFASDI",
    "Id": 15
  },
  {
    "title": "HASDFAI",
    "Id": 1
  },
  {
    "title": "ASDHFI",
    "Id": 9
  },
];

console.log(
  data.sort((a, b) => ref[a.Id] - ref[b.Id])
)


或者实现自定义管道进行排序:Angular 2 OrderBy Pipe

关于angular - 如何在 Typescript 或 Angular 中自定义排序 JSON 数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48515189/

相关文章:

javascript - 如何使用 Angular 根据在html中选择的单选按钮获取 bool 值

php - ksort 在处理字母数字字符时产生错​​误的结果

python - 使用 for 循环对列表中的数字进行排序

arrays - Laravel 按键排序

javascript - 在 typescript 中输入检查 API 响应

javascript - TypeScript 类到 JSON

javascript - 这是在 Angular 2 中实现 Pipe 的正确方法吗

typescript - 包括串联的 Typescript JS outFile - Angular 2 + Typescript

angular - 类型 'catchError' 上不存在属性 'Observable<HttpEvent<any>>'

javascript - 如何获取特定的路由器值?