Heim >Web-Frontend >Front-End-Fragen und Antworten >Benutzerdefinierte JavaScript-Funktion zum Sammeln
JavaScript ist eine High-Level-Programmiersprache, die zum Schreiben von Webanwendungen verwendet wird. Ihre leistungsstarken Fähigkeiten und ihr breites Einsatzspektrum haben sie zu einem unverzichtbaren Werkzeug in der Webentwicklung gemacht. In JavaScript sind benutzerdefinierte Funktionen eine sehr wichtige Technologie, die es uns ermöglicht, Funktionen entsprechend unseren eigenen Anforderungen zu schreiben und aufzurufen. In diesem Artikel stellen wir vor, wie Sie eine benutzerdefinierte JavaScript-Funktion zum Sammeln verwenden.
Was ist Akkumulation?
Addition ist die Addition aller Zahlen in einer Zahlenfolge. Wenn wir zum Beispiel die Zahlenfolge 1, 2, 3, 4, 5 haben, dann ist das Gesamtergebnis 15 (also 1 + 2 + 3 + 4 + 5).
Wie verwende ich benutzerdefinierte JavaScript-Funktionen zum Akkumulieren?
Um benutzerdefinierte JavaScript-Funktionen zum Akkumulieren zu verwenden, müssen wir Variablen, Schleifen und bedingte Anweisungen verwenden.
Hier ist ein einfachstes Akkumulierungsprogramm:
function sum(arr) { var s = 0; for (var i = 0; i < arr.length; i++) { s += arr[i]; } return s; } var arr = [1, 2, 3, 4, 5]; console.log(sum(arr)); // 15
Lassen Sie uns dieses Programm Schritt für Schritt aufschlüsseln:
Wir können es testen, indem wir die Summenfunktion aufrufen und eine Zahlenfolge übergeben. In diesem Beispiel definieren wir eine Zahlenfolge arr = [1, 2, 3, 4, 5] und verwenden die Funktion console.log, um das kumulative Ergebnis auszugeben.
Das obige Programm ist die grundlegendste Form einer benutzerdefinierten JavaScript-Funktion zur Akkumulation. Allerdings lässt es einiges zu wünschen übrig.
Fehlerbehandlung
Das vorherige Programm geht davon aus, dass die Eingabedaten korrekt und gültig sind, und führt Berechnungen direkt durch. In realen Anwendungen ist es jedoch wahrscheinlich, dass wir auf falsche Eingabedaten oder andere Fehler stoßen.
Um ein robusteres Programm zu schreiben, müssen wir einen Fehlerbehandlungsmechanismus hinzufügen. Hier ist ein verbessertes Akkumulierungsprogramm:
function sum(arr) { if (!Array.isArray(arr)) { throw new TypeError('sum() expects an array as parameter.'); } var s = 0; for (var i = 0; i < arr.length; i++) { if (typeof arr[i] !== 'number') { throw new TypeError('sum() expects an array of numbers.'); } s += arr[i]; } return s; } var arr = [1, 2, 3, 4, 5]; console.log(sum(arr)); // 15 console.log(sum('12345')); // TypeError: sum() expects an array as parameter. console.log(sum([1, '2', 3, 4])); // TypeError: sum() expects an array of numbers.
In dieser Version haben wir zwei Fehlerbehandlungsbedingungen hinzugefügt:
Die Fehlerbehandlung kann die Robustheit und Zuverlässigkeit des Programms erheblich verbessern und sicherstellen, dass unsere Funktionen unter unerwarteten Umständen korrekt ausgeführt werden können.
Funktionssignatur
Bei der Programmierung bezieht sich die Funktionssignatur auf den Namen, die Parameter und den Rückgabewerttyp der Funktion. Die Bestimmung von Funktionssignaturen kann uns helfen, Funktionen leichter zu verstehen und zu nutzen.
Die Funktionssignatur sollte Folgendes enthalten:
Für die Akkumulationsfunktion können wir ihre Funktion wie folgt signieren:
sum(arr: Array) => Number
Dies zeigt an, dass die Summenfunktion ein Array als Parameter erfordert und als Ergebnis eine Zahl zurückgibt.
Funktionen höherer Ordnung
In JavaScript ist eine Funktion höherer Ordnung eine Funktion, die eine Funktion als Eingabe akzeptiert oder eine Funktion als Ausgabe zurückgibt. Wir können Funktionen höherer Ordnung verwenden, um allgemeine Operationen zu kapseln und sie auf verschiedene Datentypen oder Bedingungen anzuwenden.
Zum Beispiel können wir eine allgemeine Kartenfunktion schreiben, die eine Operation auf jedes Element in einem beliebigen Array anwenden kann. Sehen wir uns an, wie man diese Funktion schreibt:
function map(arr, f) { if (!Array.isArray(arr)) { throw new TypeError('map() expects an array as parameter.'); } if (typeof f !== 'function') { throw new TypeError('map() expects a function as second parameter.'); } var result = []; for (var i = 0; i < arr.length; i++) { result.push(f(arr[i])); } return result; } var arr = [1, 2, 3, 4, 5]; console.log(map(arr, x => 2 * x)); // [2, 4, 6, 8, 10] var words = ['JavaScript', 'is', 'awesome']; console.log(map(words, w => w.toUpperCase())); // ['JAVASCRIPT', 'IS', 'AWESOME']
Diese Funktion benötigt zwei Parameter: ein Array arr und eine Funktion f. Die Funktion f wird auf jedes Element im Array angewendet und gibt das berechnete Ergebnis zurück.
Wir können die Map-Funktion verwenden, um verschiedene Operationen anzuwenden, z. B. die Multiplikation auf jedes Element im Zahlenarray und die Umwandlung in Großbuchstaben auf jedes Element im String-Array. Da es sich bei der Kartenfunktion um eine allgemeine Operation handelt, müssen wir sie nur einmal definieren und in mehreren Szenarien verwenden.
Zusammenfassung:
Durch die Einleitung dieses Artikels haben wir gelernt, wie man benutzerdefinierte JavaScript-Funktionen zum Sammeln verwendet. Wir haben gelernt, wie man mit Fehlern umgeht, Funktionssignaturen definiert und Funktionen höherer Ordnung verwendet. Benutzerdefinierte JavaScript-Funktionen sind sehr flexibel und leistungsstark und ermöglichen es uns, Funktionen entsprechend unseren eigenen Anforderungen zu schreiben und aufzurufen, wodurch die Wiederholbarkeit und Wartbarkeit des Codes verbessert wird.
Das obige ist der detaillierte Inhalt vonBenutzerdefinierte JavaScript-Funktion zum Sammeln. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!