Heim > Web-Frontend > js-Tutorial > Sprechen Sie kurz über die indexOf-Methode im JS-Array

Sprechen Sie kurz über die indexOf-Methode im JS-Array

高洛峰
Freigeben: 2017-01-14 10:38:01
Original
1409 Leute haben es durchsucht

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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
Nach dem Login kopieren

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!

Verwandte Etiketten:
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage