Heim > Web-Frontend > js-Tutorial > Wie kann ich Objekte in einem JavaScript-Array basierend auf dem Attributwert effizient finden?

Wie kann ich Objekte in einem JavaScript-Array basierend auf dem Attributwert effizient finden?

Mary-Kate Olsen
Freigeben: 2024-12-10 08:44:17
Original
515 Leute haben es durchsucht

How Can I Efficiently Find Objects in a JavaScript Array Based on Attribute Value?

Objekte in Arrays basierend auf dem Attributwert lokalisieren

Stellen Sie sich ein Array vor wie:

vendors = [{
    Name: 'Magenic',
    ID: 'ABC'
  },
  {
    Name: 'Microsoft',
    ID: 'DEF'
  }, // and so on...
];
Nach dem Login kopieren

Wie können Sie dies effizient tun? feststellen, ob „Magenic“ in diesem Array vorhanden ist? So erreichen Sie dies, ohne auf explizite Schleifen zurückgreifen zu müssen, was besonders nützlich ist, wenn Sie mit großen Datensätzen arbeiten:

Verwenden der Methode „some“, um ein einzelnes passendes Element zu finden:

if (vendors.some(e => e.Name === 'Magenic')) {
  // A matching object is found!
}
Nach dem Login kopieren

Abrufen der passendes Objekt mit find:

if (vendors.find(e => e.Name === 'Magenic')) {
  // Returns the object itself, not just a boolean.
}
Nach dem Login kopieren

Suchen des Index des ersten passenden Elements mit findIndex:

const i = vendors.findIndex(e => e.Name === 'Magenic');
if (i > -1) {
  // Indicates a matching object found at index i.
}
Nach dem Login kopieren

Wenn mehrere übereinstimmende Objekte erforderlich sind, verwenden Sie den Filter:

if (vendors.filter(e => e.Name === 'Magenic').length > 0) {
  // Returns all objects that satisfy the condition.
}
Nach dem Login kopieren

Für Browser ohne Unterstützung für Pfeilfunktionen:

if (vendors.filter(function(e) { return e.Name === 'Magenic'; }).length > 0) {
  // Same as above, using traditional function syntax.
}
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann ich Objekte in einem JavaScript-Array basierend auf dem Attributwert effizient finden?. 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