>웹 프론트엔드 >JS 튜토리얼 >JavaScript 객체에서 Null 및 정의되지 않은 속성을 제거하려면 어떻게 해야 합니까?

JavaScript 객체에서 Null 및 정의되지 않은 속성을 제거하려면 어떻게 해야 합니까?

DDD
DDD원래의
2024-12-02 00:53:10710검색

How Can I Remove Null and Undefined Attributes from a JavaScript Object?

JavaScript의 객체에서 빈 속성 제거

JavaScript 객체 속성에는 때때로 정의되지 않은 값이나 null 값이 포함될 수 있습니다. 이는 데이터 작업 시 어려움을 초래할 수 있으며 일관성과 정확성을 유지하는 것을 어렵게 만들 수 있습니다. 이러한 빈 속성을 제거하면 코드를 최적화하고 데이터 무결성을 향상시키는 데 도움이 될 수 있습니다.

개요

JavaScript 개체에서 정의되지 않았거나 null인 모든 속성을 제거하려면 다음 접근 방식을 사용할 수 있습니다.

반복(함수형) 스타일)

  1. ES10/ES2019 예:

    let o = Object.fromEntries(Object.entries(obj).filter(([_, v]) => v != null));
  2. ES6/ES2015 예:

    let o = Object.keys(obj)
      .filter((k) => obj[k] != null)
      .reduce((a, k) => ({ ...a, [k]: obj[k] }), {});

반복(명령형 스타일)

  1. ES10/ES2019 예:

    function removeEmpty(obj) {
      const newObj = {};
      Object.entries(obj).forEach(([k, v]) => {
        if (v === Object(v)) {
          newObj[k] = removeEmpty(v);
        } else if (v != null) {
          newObj[k] = obj[k];
        }
      });
      return newObj;
    }

재귀

  1. ES10/ES2019 예:

    function removeEmpty(obj) {
      return Object.fromEntries(
        Object.entries(obj)
          .filter(([_, v]) => v != null)
          .map(([k, v]) => [k, v === Object(v) ? removeEmpty(v) : v])
      );
    }

위 내용은 JavaScript 객체에서 Null 및 정의되지 않은 속성을 제거하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.