Bitte vermeiden Sie von nun an die Verwendung von if-Anweisungen zur Umsetzung unseres Geschäfts.
Sie fragen sich vielleicht, welche Vorteile es hat, wenn Sie nicht if verwenden. Nun ja, vielleicht gibt es keinen offensichtlichen Vorteil, es ist nur eine andere Denkweise, um das Problem zu lösen. An if-else ist nichts auszusetzen, aber in manchen Fällen kann eine große Anzahl von if-else dazu führen, dass der Code weniger lesbar ist. Nachfolgend finden Sie einige Beispiele, die Ihnen helfen sollen, das Geheimnis zu spüren.
Codierungstipp: Versuchen Sie, ohne If-Anweisungen zu codieren
Zählen Sie bei einem gegebenen Array vom Typ Integer die Anzahl der ungeraden Zahlen im Array
const arrayOfIntegers = [1, 4, 5, 9, 0, -1, 5];
wenn Implementierung
let counter = 0; arrayOfIntegers.forEach((integer) => { const remainder = Math.abs(integer % 2); if (remainder === 1) { counter++; } }); console.log(counter);
nicht-wenn Implementierung
let counter = 0; arrayOfIntegers.forEach((integer) => { const remainder = Math.abs(integer % 2); // 偶数除2的余数为零,奇数的余数为一 counter += remainder; }); console.log(counter);
Hinweis: In den beiden obigen Beispielen ändert forEach das ursprüngliche Array und die Methode ist 可变的
, was gegen das aktuelle Konzept der funktionalen Programmierung verstößt. immutable
Keine Sorge, das ist nicht der Fall Schwerpunkt dieses Artikels. Beim Vergleich der beiden Beispiele ist die Implementierung von if语句
möglicherweise kompatibler und kann an die Situation angepasst werden, in der das Array-Element 小数
ist. Wenn die Array-Elemente vom Typ Gleitkomma sind, funktioniert das zweite Beispiel nicht ordnungsgemäß.
implementiert eine Funktion, die ein Datumsobjekt new Date()
als Eingabe verwendet und zurückgibt, ob der aktuelle Tag 工作日
ist oder 周末
basierend auf unterschiedlichen Daten.
If-Implementierung
const weekendOrWeekday = inputDate => { const day = inputDate.getDay(); if (day === 0 || day === 6) { return 'weekend'; } return 'weekday'; // Or, for ternary fans: // return (day === 0 || day === 6) ? 'weekend' : 'weekday'; }; console.log(weekendOrWeekday(new Date()));
Nicht-If-Implementierung
const weekendOrWeekday = (inputDate) => { const day = inputDate.getDay(); return weekendOrWeekday.labels[day] || weekendOrWeekday.labels['default']; }; weekendOrWeekday.labels = { 0: 'weekend', 6: 'weekend', default: 'weekday' }; console.log(weekendOrWeekday(new Date()));
Ist Ihnen aufgefallen, dass die Zahl in if语句
angibt, welcher Tag das Wochenende ist, und die Bedingung bestimmt? Verteilung Es ist fragmentierter. Wir müssen Zahlen den 周末或工作日
-Typen zuordnen. Wie in Beispiel 2 können Sie ein Objekt oder eine Karte verwenden, um die entsprechende Beziehung zu speichern.
Beim Vergleich der beiden oben genannten Beispiele ist deutlich zu erkennen, dass die 非if代码
-Implementierung eine bessere Lesbarkeit und Skalierbarkeit aufweist
implementiert eine Verdoppelungsfunktion und führt die folgende Verarbeitung entsprechend verschiedenen Eingaben durch:
Wenn die Eingabe vom Typ number
ist, tun Sie dies der Verdopplungsprozess (5 => 10, -10 => -20)
Wenn die Eingabe vom Typ string
ist, wiederholen Sie jedes Zeichen ('hello' => 'hheelloo')
Wenn die Eingabe vom Typ function
ist, rufen Sie die Funktion zweimal auf und führen Sie sie aus
Wenn die Eingabe vom Typ ist array
, führen Sie dies für jedes Element des Arrays aus. doubler
Verarbeitung
Wenn die Eingabe vom Typ object
ist, führen Sie die doubler
Verarbeitung für jedes Attribut des Objekts
Die Implementierung von switch
const doubler = (input) => { switch (typeof input) { case 'number': return input + input; case 'string': return input .split('') .map(letter => letter + letter) .join(''); case 'object': Object.keys(input) .map(key => (input[key] = doubler(input[key]))); return input; case 'function': input(); input(); } }; console.log(doubler(-10)); console.log(doubler('hey')); console.log(doubler([5, 'hello'])); console.log(doubler({ a: 5, b: 'hello' })); console.log( doubler(function() { console.log('call-me'); }), );
-Implementierung von switch
const doubler = (input) => { return doubler.operationsByType[typeof input](input); }; doubler.operationsByType = { number: (input) => input + input, string: (input) => input .split('') .map((letter) => letter + letter) .join(''), function: (input) => { input(); input(); }, object: (input) => { Object.keys(input) .map((key) => (input[key] = doubler(input[key]))); return input; }, }; console.log(doubler(-10)); console.log(doubler('hey')); console.log(doubler([5, 'hello'])); console.log(doubler({ a: 5, b: 'hello' })); console.log( doubler(function() { console.log('call-me'); }), );
gibt, werden die Bedingungen zentral verarbeitet (verwenden Sie Objekte, um ihre entsprechenden Beziehungen zu speichern – die Bedingungen werden als Schlüssel verwendet und die Verarbeitung erfolgt als Werte). Der Vorteil besteht darin, dass es einfacher wird, eine bestimmte Bedingung hinzuzufügen oder zu löschen, und der Code besser lesbar ist. Es wird empfohlen, einen Teil der if-else
-Bedingungsbeurteilung durch die Korrespondenz zu ersetzen. key-value
if-else
Verwandte Empfehlungen:
Das obige ist der detaillierte Inhalt vonProgrammierbeispiele ohne If-Anweisungen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!