按照它们的ID返回两种不同类型的数组的新数组
创始人
2024-08-25 11:00:51
0

假设我们有两个类别,如下所示:

class Category1 {
  id: number;
  name: string;
  constructor(id: number, name: string) {
    this.id = id;
    this.name = name;
  }
}

class Category2 {
  id: number;
  value: number;
  constructor(id: number, value: number) {
    this.id = id;
    this.value = value;
  }
}

然后我们可以定义一个函数,该函数按照它们的ID返回两个不同类型的数组,并将它们放在一个新数组中,如下所示:

function getTwoArraysById(arr: (Category1 | Category2)[]): [Category1[], Category2[]] {
  const category1Array: Category1[] = [];
  const category2Arrays: Category2[] = [];
  arr.forEach((item) => {
    if (item instanceof Category1) {
      category1Array.push(item);
    } else if (item instanceof Category2) {
      category2Arrays.push(item);
    }
  })
  return [category1Array, category2Arrays];
}

现在我们可以使用这个函数来获取两个不同类型的数组,如下所示:

const data: (Category1 | Category2)[] = [
  new Category1(1, 'Category1-1'),
  new Category2(2, 20),
  new Category2(3, 30),
  new Category1(4, 'Category1-2'),
];

const [category1Array, category2Arrays] = getTwoArraysById(data);

console.log(category1Array); // [Category1 {id: 1, name: 'Category1-1'}, Category1 {id: 4, name: 'Category1-2'}]
console.log(category2Arrays); // [Category2 {id: 2, value: 20}, Category2 {id: 3, value: 30}]

这个函数将把数组中的每个项目都分类,这样您就可以根据其ID将项目分组,并返回两个不同的类型数组。

相关内容

热门资讯

安装了Anaconda之后找不... 在安装Anaconda后,如果找不到Jupyter Notebook,可以尝试以下解决方法:检查环境...
安装安卓应用时出现“Play ... 在安装安卓应用时出现“Play Protect 警告弹窗”的原因是Google Play Prote...
安卓系统怎么连不上carlif... 安卓系统无法连接CarLife的原因及解决方法随着智能手机的普及,CarLife这一车载互联功能为驾...
避免在粘贴双引号时向VS 20... 在粘贴双引号时向VS 2022添加反斜杠的问题通常是由于编辑器的自动转义功能引起的。为了避免这个问题...
iwatch怎么连接安卓系统,... 你有没有想过,那款时尚又实用的iWatch,竟然只能和iPhone好上好?别急,今天就来给你揭秘,怎...
安装apache-beam==... 出现此错误可能是因为用户的Python版本太低,而apache-beam==2.34.0需要更高的P...
iqoo安卓14系统怎么升级系... 亲爱的iQOO手机用户们,是不是觉得你的手机系统有点儿落伍了呢?别急,今天就来手把手教你如何升级到最...
vivo安卓系统取消更新系统,... 亲爱的vivo手机用户们,你们是不是也遇到了这样的烦恼:手机里突然冒出一个更新提示,点开一看,哇,新...
Android Recycle... 要在Android RecyclerView中实现滑动卡片效果,可以按照以下步骤进行操作:首先,在项...
安卓系统连接荣耀手表,操作指南... 亲爱的手机控们,是不是最近入手了一款酷炫的荣耀手表,却不知道怎么和安卓手机完美“牵手”呢?别急,今天...