Heim > Web-Frontend > js-Tutorial > Wie entferne ich Null- und undefinierte Attribute aus einem JavaScript-Objekt?

Wie entferne ich Null- und undefinierte Attribute aus einem JavaScript-Objekt?

Barbara Streisand
Freigeben: 2024-11-27 11:39:11
Original
1025 Leute haben es durchsucht

How to Remove Null and Undefined Attributes from a JavaScript Object?

Leere Attribute aus einem Objekt in Javascript entfernen

Bei der Arbeit mit JavaScript-Objekten kann es erforderlich sein, Attribute zu entfernen, die undefiniert oder null sind . Dies kann dabei helfen, Daten zu bereinigen, unnötige Felder zu entfernen oder Objekte für die Speicherung vorzubereiten. Abhängig von der verwendeten JavaScript-Version gibt es mehrere Möglichkeiten, diese Aufgabe zu erfüllen.

ES10/ES2019

In ES10/ES2019 ist die Verwendung der einfachste Ansatz die Object.fromEntries()-Methode, um ein neues Objekt zu erstellen, das nur die nicht leeren Attribute enthält:

let o = Object.fromEntries(Object.entries(obj).filter(([_, v]) => v != null));
Nach dem Login kopieren

Dies kann auch als Funktion geschrieben werden:

function removeEmpty(obj) {
  return Object.fromEntries(Object.entries(obj).filter(([_, v]) => v != null));
}
Nach dem Login kopieren

Für verschachtelte Objekte kann eine rekursive Funktion verwendet werden:

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

ES6/ES2015

In ES6/ES2015 kann der folgende Einzeiler verwendet werden. Beachten Sie jedoch, dass er das ursprüngliche Objekt mutiert, anstatt ein neues zu erstellen eins:

Object.keys(obj).forEach((k) => obj[k] == null && delete obj[k]);
Nach dem Login kopieren

Alternativ erstellt die folgende einzelne Deklaration ein neues Objekt, ohne das Original zu verändern:

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

Dies kann auch als Funktion geschrieben werden:

function removeEmpty(obj) {
  return Object.entries(obj)
    .filter(([_, v]) => v != null)
    .reduce((acc, [k, v]) => ({ ...acc, [k]: v }), {});
}
Nach dem Login kopieren

Für verschachtelte Objekte kann die folgende rekursive Funktion sein verwendet:

function removeEmpty(obj) {
  return Object.entries(obj)
    .filter(([_, v]) => v != null)
    .reduce(
      (acc, [k, v]) => ({ ...acc, [k]: v === Object(v) ? removeEmpty(v) : v }),
      {}
    );
}
Nach dem Login kopieren

ES5/ES2009

In ES5/ES2009 ist der Code ausführlicher:

function removeEmpty(obj) {
  return Object.keys(obj)
    .filter(function (k) {
      return obj[k] != null;
    })
    .reduce(function (acc, k) {
      acc[k] = obj[k];
      return acc;
    }, {});
}
Nach dem Login kopieren

Dies kann geschrieben werden auch im imperativen Stil:

function removeEmpty(obj) {
  const newObj = {};
  Object.keys(obj).forEach(function (k) {
    if (obj[k] && typeof obj[k] === "object") {
      newObj[k] = removeEmpty(obj[k]);
    } else if (obj[k] != null) {
      newObj[k] = obj[k];
    }
  });
  return newObj;
}
Nach dem Login kopieren

Endlich eine rekursive Version in einem funktionalen Stil geschrieben:

function removeEmpty(obj) {
  return Object.keys(obj)
    .filter(function (k) {
      return obj[k] != null;
    })
    .reduce(function (acc, k) {
      acc[k] = typeof obj[k] === "object" ? removeEmpty(obj[k]) : obj[k];
      return acc;
    }, {});
}
Nach dem Login kopieren

Durch die Anwendung dieser Techniken können Sie leere Attribute effektiv aus einem Objekt in verschiedenen Versionen von JavaScript entfernen und so sicherstellen, dass Ihre Daten sauber und bereit für die weitere Verarbeitung oder Speicherung sind.

Das obige ist der detaillierte Inhalt vonWie entferne ich Null- und undefinierte Attribute aus einem JavaScript-Objekt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage