在 JavaScript 中删除重复项并映射数组

javascriptweb developmentfront end technologyobject oriented programming

假设我们有一个像这样的对象数组 −

const arr = [
   {id:123, value:"value1", name:"Name1"},
   {id:124, value:"value2", name:"Name1"},
   {id:125, value:"value3", name:"Name2"},
   {id:126, value:"value4", name:"Name2"}
];

请注意,数组中对象的某些"name"属性是重复的。

我们需要编写一个 JavaScript 函数,该函数接受一个这样的对象数组。然后,该函数应构造一个新的字符串数组,该数组仅包含数组中唯一的"name"属性值。

因此,上述输入的输出应如下所示 −

const output = ["Name1", "Name2"];

示例

其代码为 −

const arr = [
   {id:123, value:"value1", name:"Name1"},
   {id:124, value:"value2", name:"Name1"},
   {id:125, value:"value3", name:"Name2"},
   {id:126, value:"value4", name:"Name2"}
];
const pickNames = (arr = []) =>{
   const res = [];
   for (let i = arr.length; i−−;){
      if (res.indexOf(arr[i].name) < 0) {
         res.push(arr[i].name);
      };
   }
   return res;
};
console.log(pickNames(arr));

输出

控制台中的输出将是 −

[ 'Name2', 'Name1' ]

相关文章