Heim  >  Artikel  >  Web-Frontend  >  Detaillierte Erläuterung der indexOf-Methode im JavaScript-Array

Detaillierte Erläuterung der indexOf-Methode im JavaScript-Array

黄舟
黄舟Original
2017-03-03 15:14:301356Durchsuche

Ich bin kürzlich auf ein kleines Problem mit dem Code gestoßen und werde es in einem kleinen Beispiel vereinfachen, um es Ihnen zu zeigen.

Passen Sie auf und Sie werden am Ende belohnt. Kinderschuhe mit einem soliden Fundament können direkt zum Array-Typ-Einsatz übergehen.

Apropos indexOf, jeder kennt es. Es wird besonders häufig zur Beurteilung verwendet, ob eine Zeichenfolge Teilzeichenfolgen enthält (ein nützliches Werkzeug für Schüler, die mit regulären Ausdrücken nicht vertraut sind).

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 sind 0 und 3 o bzw. n in der Zeichenfolge. Die Position, an der es scheint. Der Startindex ist 0. Und -1 bedeutet keine Übereinstimmung.

Jemand hat mich einmal gefragt, warum -1 nicht null oder undefiniert ist. 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

Das Kleine, was Sie hier sehen, ist, dass indexOf einfache Typkonvertierungen durchführen und Zahlen konvertieren kann string '2' und dann ausführen.

Verwendung des Zahlentyps

Sie fragen sich vielleicht, ob der Typ number eine Methode indexOf hat, weil er 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 Methode number für den Typ indexOf verwenden? Wandeln Sie es dann in eine Zeichenfolge um 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 wie dem dritten Typ besessen sind

Array-Typ-Verwendung

Alle, Kopf hoch, der große Boss kommt.

Jeder ist mit der Array-Methode sehr vertraut, aber er hat die indexOf-Methode für Arrays übersehen (mein persönliches Gefühl).

Einfach reden, ohne zu üben. Auf welche Probleme sind Sie gestoßen?

let arr = ['orange', '2016', '2016'];

arr.indexOf('orange');  //0
arr.indexOf('o');  //-1

arr.indexOf('2016');  //1
arr.indexOf(2016);  //-1

Das Beispiel wird 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 den indexOf-Abgleich nicht erneut auf Elementbasis durchführt.

  • arr.indexOf('2016′) gibt 1 aus, da diese Methode die folgende Liste des ersten Array-Elements vom Anfang bis zum Erreichen der Übereinstimmung zurückgibt, anstatt den Index aller zurückzugeben Streichhölzer.

  • arr.indexOf(2016) Ausgabe -1 Hinweis: Hier wird keine implizite Typkonvertierung durchgeführt.

Nachdem die Falle 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).

Löschen bei Auf den ersten Blick werden hier strikte Gleichheitszeichen (===) verwendet. 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

Die Anhäufung kleiner Wissenspunkte ist kein Thema für eine eingehende Diskussion, daher wird der zweite Parameter von indexOf() hier meiner Meinung nach nicht erklärt zweiter Parameter, nein Wenn Sie wissen, können Sie sich String.prototype.indexOf() hier ansehen und dann einen Blick auf den zweiten Parameter in Verbindung mit dem Link zum Array oben werfen.

Das Obige ist die detaillierte Erklärung der indexOf-Methode in JavaScript-Arrays. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website (www.php.cn)!

Stellungnahme:
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