使用另一個數組過濾 JavaScript 物件陣列


假設我們有一個這樣的物件陣列 −

const arr = [
   {area: 'NY', name: 'Bla', ads: true},
   {area: 'DF', name: 'SFS', ads: false},
   {area: 'TT', name: 'SDSD', ads: true},
   {area: 'SD', name: 'Engine', ads: false},
   {area: 'NSK', name: 'Toyota', ads: false},
];

我們需要編寫一個 JavaScript 函式,該函式將一個這樣的陣列作為第一個引數,並將一個字串文字陣列作為第二個引數。

然後,我們的函式應該過濾輸入物件陣列,只包含那些“area”屬性包含在文字陣列(第二個引數)中的物件。

示例

程式碼為 −

const arr = [
   {area: 'NY', name: 'Bla', ads: true},
   {area: 'DF', name: 'SFS', ads: false},
   {area: 'TT', name: 'SDSD', ads: true},
   {area: 'SD', name: 'Engine', ads: false},
   {area: 'NSK', name: 'Toyota', ads: false},
];
const keys = ['NY', 'SD'];
const filterByArea = (arr = [], keys = []) => {
   const res = [];
   for(let i = 0; i < arr.length; i++){
      const { area } = arr[i];
      if(keys.includes(area)){
         res.push(arr[i]);
      };
   };
   return res;
};
console.log(filterByArea(arr, keys));

輸出

而控制檯中的輸出為 −

[
   { area: 'NY', name: 'Bla', ads: true },
   { area: 'SD', name: 'Engine', ads: false }
]

更新日期:23-11-2020

511 次瀏覽

開啟你的 職業生涯

完成課程獲得認證

開始
廣告
© . All rights reserved.