ホームページ  >  記事  >  ウェブフロントエンド  >  JS配列のindexOfメソッドの解析(例あり)

JS配列のindexOfメソッドの解析(例あり)

不言
不言転載
2018-11-15 17:48:222997ブラウズ

この記事の内容は、JS 配列の IndexOf メソッドの解析に関するものです (例付き)。必要な方は参考にしていただければ幸いです。

この 2 日間、自宅で友人のプロジェクトを手伝っていたのですが、そのプロジェクトで配列の IndexOf メソッドが使用されていたのですが、非常に良いと感じた記事を見つけました。リンクが失われるのを防ぐために。

indexOf は誰もがよく知っていると思いますが、特に文字列に部分文字列が含まれているかどうかを判断するときによく使用され、正規表現に慣れていない学生にとっては便利なツールです。この記事では、私が最近遭遇した問題に基づいた例を使用して、indexOf メソッドについて説明します。この記事は小さな知識をまとめたものであり、深く議論するトピックではありません。したがって、indexOf() の 2 番目のパラメーターの役割は誰もが知っていると思います。

文字列型の使用法

よく知られている文字列の使用法を確認します。例:

let str = 'orange';
 
str.indexOf('o'); //0
str.indexOf('n'); //3
str.indexOf('c'); //-1

ここで、0 と 3 はそれぞれ o と n です。文字列内で発生する場所。開始インデックスは 0 です。 -1 は一致しないことを意味します。
ある人が、なぜ -1 が nullunknown ではないのかと尋ねたことがあります。ルール作った人に聞いてみよう!無力感の表情。
ここにはハイライトがないと誰もが感じていますが、焦らずに別の例を挙げてみましょう

let numStr = '2016';
 
numStr.indexOf('2'); //0
numStr.indexOf(2); //0

ここで小さなポイントがあります。indexOf は単純な型変換を実行し、数値を文字列に変換します。 2' を指定してから を実行します。

Number 型の使用

Number 型には暗黙的な変換が実行されるため、indexOf メソッドがあるかどうか疑問に思うかもしれません。はっきり言っておきますが、いいえ、上記の例

let num = 2016;
 
num.indexOf(2); //Uncaught TypeError: num.indexOf is not a function

number 型に対して IndexOf メソッドを使用する必要がありますか?次に、それを文字列に変換し、上記の例で

//二逼青年的写法
num = '2016';
num.indexOf(2); //0
 
//普通青年的写法
num.toString().indexOf(2); //0
 
//文艺青年的写法
('' + num).indexOf(2); //0

と記述します。最初の記述方法は単純かつ直接的であり、既知の短い数値であれば不可能ではありません。しかし、異なるデータに対して num 変数が変更された場合はどうすればよいでしょうか?

2 番目の書き方が最も一般的に使用されますが、3 番目の書き方より少し長くなります。あはは、実際のところ、コードに夢中になっている人は 3 番目の √ を好みます。

配列型の使用法

みんな元気出して、大ボスがやってくるよ。
配列メソッドについては誰もがよく知っていますが、配列にindexOfメソッドがあることを無視しています(私の個人的な感覚です)。
練習もせずにくだらない話をしてしまいましたが、どのような問題が発生しましたか?また、どのような点に注意する必要がありますか?

let arr = ['orange', '2016', '2016'];
 
arr.indexOf('orange'); //0
arr.indexOf('o'); //-1
 
arr.indexOf('2016'); //1
arr.indexOf(2016); //-1

ここでは例を詳しく説明しませんが、問題を説明するには 4 つの使用例だけで十分です。

arr.indexOf(‘orange’) 「orange」は配列の 0 番目の要素であり、インデックスが一致して返されるため、0 を出力します。
arr.indexOf('o') このメソッドは要素ごとに IndexOf マッチングを再度実行しないため、-1 が出力されます。
arr.indexOf('2016') 出力 1 このメソッドは、一致するすべてのインデックスを返すのではなく、先頭から一致に達するまでの最初の配列要素の次のリストを返すためです。
arr.indexOf(2016) Output -1 注: ここでは暗黙的な型変換は行われません。

穴が発見されたので、その底に到達したほうがよいでしょう。 MDN 公式 Web サイトにアクセスして確認してください。このトピックに興味のある友人は、Array.prototype.indexOf() に直接ジャンプできます。

もっと知りたい人のために、ここに公式の説明があります。

indexOf() は、厳密な等価性 (=== またはトリプル等号演算子で使用されるのと同じ方法) を使用して、searchElement を配列の要素と比較します。

一目瞭然、ここで使用されるのは (===) と厳密に同じです。同様の判断をされる場合には、より一層ご注意ください。数値は文字列に変換され、文字列は数値に変換されないと誤解しないでください。

まとめ

以上がこの記事の全内容です、この記事の内容が皆さんの勉強や仕事に少しでもお役に立てれば幸いです。質問、メッセージを残してコミュニケーションをとることができます。

  • String:indexOf は数値 0 に対して型変換を実行し、文字列 '0' に変換します。

  • 番号:indexOf メソッドはありません。数値型を文字列に変換する必要があります。方法は 3 つあります。直接文字列、文字列 toString、文字列連結。

  • Array: 配列にもindexOfメソッドがありますが、型判定を行う際には厳密な等価性、つまり===が使用されます。

以上がJS配列のindexOfメソッドの解析(例あり)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はhttps://segmentfault.com/a/1190000017001710で複製されています。侵害がある場合は、admin@php.cn までご連絡ください。