Heim >Web-Frontend >js-Tutorial >Sprechen Sie kurz über die indexOf-Methode im JS-Array
Vorwort
Ich glaube, jeder kennt indexOf. Es wird besonders häufig verwendet, wenn es darum geht, zu beurteilen, ob eine Zeichenfolge Teilzeichenfolgen enthält. Es ist ein nützliches Werkzeug für Schüler, die mit regulären Ausdrücken nicht vertraut sind. In diesem Artikel wird anhand eines Beispiels über die indexOf-Methode gesprochen, basierend auf einem Problem, auf das ich kürzlich gestoßen bin. Dieser Artikel ist eine Ansammlung kleiner Wissenspunkte und kein Thema für eine ausführliche Diskussion. Daher wird der zweite Parameter von indexOf() hier meiner Meinung nach nicht jeder kennt.
Verwendung des String-Typs
Sehen Sie sich zum Beispiel die bekannte String-Verwendung an
let str = 'orange'; str.indexOf('o'); //0 str.indexOf('n'); //3 str.indexOf('c'); //-1
hier 0 bzw. 3 Ist die Position, an der o und n in der Zeichenfolge erscheinen. Der Startindex ist 0. Und -1 bedeutet keine Übereinstimmung.
Jemand hat mich einmal gefragt, warum es -1 statt null oder undefiniert sei. Fragen Sie die Person, die die Regeln aufgestellt hat! Ein Blick der Hilflosigkeit.
Jeder sieht hier nichts Interessantes, keine Sorge, hier ist ein weiteres Beispiel
let numStr = '2016'; numStr.indexOf('2'); //0 numStr.indexOf(2); //0
Ein kleiner Punkt hier ist, dass indexOf einfache Typen konvertieren kann , wandeln Sie die Zahl in die Zeichenfolge „2“ um und führen Sie sie dann aus.
Verwendung des Zahlentyps
Sie fragen sich vielleicht, ob der Zahlentyp eine indexOf-Methode hat, weil diese eine implizite Konvertierung durchführt! Lassen Sie mich klar sagen: Nein, im obigen Beispiel
let num = 2016; num.indexOf(2); //Uncaught TypeError: num.indexOf is not a function
müssen Sie die indexOf-Methode für den Zahlentyp verwenden? Konvertieren Sie es dann in eine Zeichenfolge und schreiben Sie dann
//二逼青年的写法 num = '2016'; num.indexOf(2); //0 //普通青年的写法 num.toString().indexOf(2); //0 //文艺青年的写法 ('' + num).indexOf(2); //0
im obigen Beispiel. Die erste Schreibweise ist einfach und direkt und für bekannte kürzere Zahlen nicht unmöglich. Aber was sollen wir tun, wenn sich die Variable „num“ für verschiedene Daten ändert? ❌
Die zweite Schreibweise wird am häufigsten verwendet, ist aber etwas länger als die dritte Schreibweise. Haha, tatsächlich ist alles möglich. Leute, die von Code besessen sind, bevorzugen die dritte Methode ✅
Verwenden des Array-Typs
Alles gute Laune, der große Boss kommt.
Jeder ist mit Array-Methoden vertraut, aber sie ignorieren, dass Arrays die indexOf-Methode haben (mein persönliches Gefühl).
Nur reden und nicht üben, auf welche Probleme sind Sie gestoßen, worauf sollten Sie achten?
let arr = ['orange', '2016', '2016']; arr.indexOf('orange'); //0 arr.indexOf('o'); //-1 arr.indexOf('2016'); //1 arr.indexOf(2016); //-1
Die Beispiele werden hier nicht im Detail aufgeschlüsselt. Vier Anwendungsfälle reichen aus, um das Problem zu veranschaulichen.
arr.indexOf('orange') gibt 0 aus, da 'orange' das 0. Element des Arrays ist und der Index abgeglichen und zurückgegeben wird.
arr.indexOf(‘o’) gibt -1 aus, da diese Methode keinen erneuten IndexOf-Abgleich pro Element durchführt.
arr.indexOf(‘2016’) gibt 1 aus, da diese Methode die Tabelle unten des ersten Array-Elements vom Anfang bis zum Erreichen der Übereinstimmung zurückgibt, anstatt alle passenden Indizes zurückzugeben.
arr.indexOf(2016) Ausgabe -1 Hinweis: Hier wird keine implizite Typkonvertierung durchgeführt.
Nachdem die Grube entdeckt wurde, können wir ihr genauso gut auf den Grund gehen. Besuchen Sie die offizielle MDN-Website, um es herauszufinden. Freunde, die sich für dieses Thema interessieren, können direkt zu Array.prototype.indexOf() springen
Für diejenigen, die einfach mehr wissen möchten, finden Sie hier die offizielle Beschreibung.
indexOf() vergleicht searchElement mit Elementen des Arrays unter Verwendung strikter Gleichheit (dieselbe Methode, die vom ===- oder Triple-Equals-Operator verwendet wird).
Es ist bei a klar Auf den ersten Blick ist das, was hier verwendet wird, genau gleich (===). Seien Sie bitte aufmerksamer, wenn Sie ähnliche Urteile fällen. Machen Sie nicht den Fehler zu glauben, dass Zahlen in Zeichenfolgen umgewandelt werden und Zeichenfolgen nicht in Zahlen.
Zusammenfassung
Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, dass der Inhalt dieses Artikels für alle beim Lernen oder bei der Arbeit hilfreich sein kann eine Botschaft zum Mitteilen.
Weitere Artikel über die indexOf-Methode in JS-Arrays finden Sie auf der chinesischen PHP-Website!