Heim > Web-Frontend > js-Tutorial > Versteckte JavaScript-Gems, die Sie in jedem Projekt in 4 verwenden sollten

Versteckte JavaScript-Gems, die Sie in jedem Projekt in 4 verwenden sollten

Barbara Streisand
Freigeben: 2024-11-22 12:50:16
Original
880 Leute haben es durchsucht

Hidden JavaScript Gems You Should Use in Every Project in 4

JavaScript ist das Rückgrat der modernen Webentwicklung und mit seinem sich ständig weiterentwickelnden Ökosystem gibt es immer etwas Neues und Aufregendes zu entdecken. In diesem Artikel tauchen wir in 10 versteckte Schätze ein – JavaScript-Methoden, APIs und Techniken –, die Ihre Projekte im Jahr 2024 auf Hochtouren bringen können. Jede dieser Funktionen ist darauf ausgelegt, Zeit zu sparen, die Entwicklung zu vereinfachen oder neue Möglichkeiten zu erschließen.

  1. Intl API zur Formatierung Die Intl API ist ein Kraftpaket für Internationalisierung und Formatierung. Unabhängig davon, ob Sie mit Datumsangaben, Zahlen oder Währungen arbeiten, erleichtert diese API die Darstellung von Daten in einem benutzerfreundlichen und länderspezifischen Format.

Beispiel: Währung formatieren

const formatter = new Intl.NumberFormat('en-US', {
  style: 'currency',
  currency: 'USD',
});
console.log(formatter.format(123456.789)); // Output: "3,456.79"
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: E-Commerce-Plattformen oder jede Anwendung, die Geldwerte anzeigt.

Warum es ein Juwel ist: Sie können mehrere Gebietsschemata mit einer einzigen API verwalten und vermeiden so die Komplexität der manuellen Formatierung.

  1. structuredClone() für Deep Copying Verabschieden Sie sich davon, benutzerdefinierte Deep-Copy-Funktionen zu schreiben oder sich auf Bibliotheken von Drittanbietern wie lodash zu verlassen. structureClone() ist eine integrierte JavaScript-Methode, die eine saubere und effiziente Möglichkeit zum tiefen Klonen von Objekten bietet.

Beispiel: Klonen eines Objekts

const original = { name: 'John', details: { age: 30 } };
const clone = structuredClone(original);

clone.details.age = 31;
console.log(original.details.age); // Output: 30
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: Klonen verschachtelter Objekte in der Zustandsverwaltung oder Datenverarbeitung.

Warum es ein Juwel ist: Es ist schnell, einfach und funktioniert mit komplexen Datenstrukturen wie Karten, Mengen und sogar Datumsangaben.

  1. Signal-API für abbrechbare Abrufanforderungen Mit der Signal-API können Sie Abrufanfragen abbrechen und haben so mehr Kontrolle über Ihren Netzwerkbetrieb. Dies ist besonders nützlich in Szenarien, in denen Benutzer möglicherweise wegnavigieren oder mehrere Anfragen auslösen.

Beispiel: Eine Abrufanforderung abbrechen

const controller = new AbortController();

fetch('https://api.example.com/data', { signal: controller.signal })
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.error('Fetch aborted:', error));

// Abort the request
controller.abort();
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: Verbesserung der Leistung bei Such- oder Autovervollständigungskomponenten durch Abbrechen unnötiger Anfragen.

Warum es ein Juwel ist: Es verhindert unnötige Verarbeitung, spart Bandbreite und steigert so die Leistung.

  1. flatMap() zum Reduzieren und Zuordnen von Arrays flatMap() kombiniert die Leistungsfähigkeit von map() und flat() und ermöglicht es Ihnen, Arrays in einem Arbeitsgang zu transformieren und zu reduzieren.

Beispiel: Abflachen und Transformieren

const nested = [[1], [2, 3], [4]];
const result = nested.flatMap(num => num.map(x => x * 2));
console.log(result); // Output: [2, 4, 6, 8]
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: Arbeiten mit hierarchischen Daten oder Transformieren von Arrays mit verschachtelten Strukturen.

Warum es ein Juwel ist: Es vereinfacht Vorgänge, die sonst mehrere verkettete Methoden erfordern würden.

  1. WeakRef für die Speicherverwaltung Mit dem WeakRef-Objekt können Sie schwache Referenzen auf Objekte erstellen und so verhindern, dass diese unnötig im Speicher verbleiben. Dies ist nützlich für die Speicherverwaltung in großen Anwendungen.

Beispiel: Verwendung von WeakRef

let obj = { name: 'Memory Intensive Object' };
const ref = new WeakRef(obj);

// Access the object
console.log(ref.deref()?.name); // Output: "Memory Intensive Object"

// Dereference to free memory
obj = null;
console.log(ref.deref()); // Output: undefined
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: Umgang mit Objekten im Cache oder datenintensiven Anwendungen.

Warum es ein Juwel ist: Es hilft, Speicherverluste zu reduzieren und die Ressourcennutzung zu optimieren.

  1. Dynamischer import() für die Codeaufteilung Mit der dynamischen import()-Funktion können Sie Module asynchron laden, was sie ideal zur Verbesserung der App-Leistung durch Aufteilen des Codes in Blöcke macht.

Beispiel: Lazy Loading eines Moduls

const formatter = new Intl.NumberFormat('en-US', {
  style: 'currency',
  currency: 'USD',
});
console.log(formatter.format(123456.789)); // Output: "3,456.79"
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: Progressive Belastung nicht kritischer Ressourcen in SPAs.

Warum es ein Juwel ist: Es ist ein Muss für die Optimierung von Leistung und Benutzererfahrung.

  1. Intl.RelativeTimeFormat für menschenlesbare Zeit Mit der API Intl.RelativeTimeFormat ist es einfach, relative Zeiten wie „vor 3 Tagen“ oder „in 2 Stunden“ zu formatieren.

Beispiel: Anzeige der relativen Zeit

const original = { name: 'John', details: { age: 30 } };
const clone = structuredClone(original);

clone.details.age = 31;
console.log(original.details.age); // Output: 30
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: Social-Media-Apps oder Blogs, die Zeitstempel anzeigen.

Warum es ein Juwel ist: Es vereinfacht eine häufige Aufgabe und unterstützt gleichzeitig mehrere Sprachen.

  1. Promise.allSettled() für den Umgang mit mehreren Versprechen Wenn Sie mit mehreren Versprechen arbeiten, stellt Promise.allSettled() sicher, dass Sie Ergebnisse für alle erhalten, unabhängig davon, ob sie erfolgreich sind oder nicht.

Beispiel: Umgang mit mehreren Versprechen

const controller = new AbortController();

fetch('https://api.example.com/data', { signal: controller.signal })
  .then(response => response.json())
  .then(data => console.log(data))
  .catch(error => console.error('Fetch aborted:', error));

// Abort the request
controller.abort();
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: Abrufen von Daten von mehreren APIs, wobei einige möglicherweise fehlschlagen.

Warum es ein Juwel ist: Es liefert umfassende Ergebnisse ohne Kurzschlüsse bei Fehlern.

  1. Optionale Verkettung für sicheren Zugang zum Eigentum Die optionale Verkettung (?.) ist ein Lebensretter für den Zugriff auf tief verschachtelte Eigenschaften, ohne sich um Null- oder undefinierte Fehler sorgen zu müssen.

Beispiel: Zugriff auf verschachtelte Eigenschaften

const nested = [[1], [2, 3], [4]];
const result = nested.flatMap(num => num.map(x => x * 2));
console.log(result); // Output: [2, 4, 6, 8]
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: Arbeiten mit APIs oder komplexen Datenstrukturen.

Warum es ein Juwel ist: Es reduziert den Boilerplate und vermeidet Laufzeitfehler.

  1. URL-API für URL-Manipulation Die URL-API bietet eine elegante Möglichkeit, URLs im Browser oder Node.js zu bearbeiten.

Beispiel: Ändern einer URL

let obj = { name: 'Memory Intensive Object' };
const ref = new WeakRef(obj);

// Access the object
console.log(ref.deref()?.name); // Output: "Memory Intensive Object"

// Dereference to free memory
obj = null;
console.log(ref.deref()); // Output: undefined
Nach dem Login kopieren
Nach dem Login kopieren

Anwendungsfall: Abfragezeichenfolgen in Webanwendungen verwalten.

Warum es ein Juwel ist: Es ist zuverlässiger und lesbarer als die Verkettung von Zeichenfolgen.

Fazit
JavaScript steckt voller versteckter Schätze, die Ihr Leben als Entwickler einfacher und effizienter machen können. Durch die Integration dieser APIs, Methoden und Techniken in Ihre Projekte werden Sie im Jahr 2024 saubereren, wartbareren und leistungsfähigeren Code schreiben.

Welche dieser Juwelen möchten Sie gerne in Ihrem nächsten Projekt verwenden? Teilen Sie Ihre Gedanken in den Kommentaren unten mit!

Bleiben Sie in Verbindung
Weitere JavaScript-Tipps und Tutorials:

? Besuchen Sie unsere Website: GladiatorsBattle.com
? Folgen Sie uns auf Twitter: @GladiatorsBT
? Entdecken Sie unsere DEV-Artikel: @GladiatorsBT
? Schauen Sie sich interaktive Demos zu CodePen an: HanGPIIIErr
Lasst uns gemeinsam etwas Großartiges aufbauen! ?

Das obige ist der detaillierte Inhalt vonVersteckte JavaScript-Gems, die Sie in jedem Projekt in 4 verwenden sollten. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:dev.to
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