在 JavaScript 中對物件進行迭代表現形式並移除假屬性


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

const obj = {
   a: {
      someKey: {
         propOne: '',
         enabled: true
      }
   },
   b: {
      someKey: {
         propOne: '',
         enabled: false
      }
   },
   c: {
      someKey: {
         propOne: '',
         enabled: false
      }
   },
   someKey: {
      ab: {
         propOne: '',
         enabled: true
      }
   }
};

我們需要編寫一個 JavaScript 函式,該函式接收一個這樣的物件,並且遞迴地在該物件中移除所有值不實的 "enabled" 屬性。

示例

程式碼如下 −

const obj = {
   a: {
      someKey: {
         propOne: '',
         enabled: true
      }
   },
   b: {
      someKey: {
         propOne: '',
         enabled: false
      }
   },
   c: {
      someKey: {
         propOne: '',
         enabled: false
      }
   },
   someKey: {
      ab: {
         propOne: '',
         enabled: true
      }
   }
};
const deleteFalsyKey = obj => {
   const keys = Object.keys(obj);
   keys.forEach(key => {
      if(obj[key].enabled === false){
         delete obj[key];
         return;
      };
      if(obj[key] && typeof obj[key] === 'object'){
         deleteFalsyKey(obj[key]);
         if (!Object.keys(obj[key]).length) {
            delete obj[key];
         };
      }
   });
};
deleteFalsyKey(obj);
console.log(obj);

輸出

控制檯中的輸出 −

{
   a: { someKey: { propOne: '', enabled: true } },
   someKey: { ab: { propOne: '', enabled: true } }
}

更新於:12-10-2020

1000+ 次瀏覽

啟動您的 職業生涯

透過完成課程以獲得認證

開始
廣告
© . All rights reserved.