ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript配列のindexOfメソッドの詳細説明

JavaScript配列のindexOfメソッドの詳細説明

黄舟
黄舟オリジナル
2017-03-03 15:14:301448ブラウズ

最近、プロジェクトで小さな問題が発生したため、コードを簡略化して小さな例にしてみんなに見せる予定です。

最後に注意を払えば、必ず報われるでしょう。基礎がしっかりしている子供用の靴は、配列型の使用に直接ジャンプできます。

indexOf は誰もがよく知っています。これは、文字列に部分文字列が含まれているかどうかを判断するときに特によく使用されます (正規表現に慣れていない学生にとっては便利なツールです)。

文字列型の使用法

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

let str = 'orange';

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

ここで、0 と 3 は、それぞれ文字列内で o と n が現れる位置です。開始インデックスは 0 です。 -1 は一致しないことを意味します。

かつて誰かが、なぜ -1 が null または未定義ではないのかと尋ねました。ルール作った人に聞いてみよう!無力感の表情。

ここには何も興味深いものはありませんが、心配しないでください。ここに別の例があります

let numStr = '2016';

numStr.indexOf('2');  //0
numStr.indexOf(2);  //0

ここで小さなポイントがあります。indexOf は単純な型変換を実行し、数値を文字列 に変換します。 ' を入力して実行します。 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 变量针对不同数据是变化的时候,怎么办呢?

第二种写法最为常用,但对比第三种写法长了一点。哈哈,其实都可以,代码洁癖的人喜欢第三种

Array 类型的使用

大家提起精神,大boss来了。

数组方法大家再熟悉不过了,却忽略了数组有 indexOf 这个方法(我个人感觉)。

干说不练瞎扯淡,遇到了什么问题,注意点又在哪里?

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

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

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

这里没把例子拆的那么细,四个用例足以说明问题。

  • arr.indexOf(‘orange’) 输出 0 因为 ‘orange’ 是数组的第 0 个元素,匹配到并返回下标。

  • arr.indexOf(‘o’) 输出 -1 因为此方法不会在每一个元素的基础上再次执行 indexOf 匹配。

  • arr.indexOf(’2016′) 输出 1 因为此方法从头匹配直到匹配到时返回第一个数组元素的下表,而不是返回全部匹配的下标。

  • arr.indexOf(2016) 输出 -1 注意:这里不会做隐式类型转换。

既然坑已经发现我们不妨刨根问底。去MDN官网一看究竟。对此话题感兴趣的朋友可以直接跳转到 Array.prototype.indexOf()

只想了解的朋友下面给大家官方的 Description。

indexOf() compares searchElement to elements of the Array using strict equality (the same method used by the === or triple-equals operator).

一目了然,这里用的是严格等于(===

Number 型の使用法

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

rrreee

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

rrreee

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

2 番目の書き方が最も一般的に使用されますが、3 番目の書き方より少し長くなります。はは、実際のところ、すべて問題ありません。コードに夢中になっている人は、3 番目の 🎜🎜配列型 🎜🎜 を使用することを好みます。皆さん、元気を出してください。ビッグボスがやって来ます。 🎜🎜配列メソッドについては誰もがよく知っていますが、配列には indexOf メソッドがあることを見落としています (私の個人的な感覚です)。 🎜🎜どのような問題が発生しましたか?何に注意する必要がありますか? 🎜rrreee🎜 ここでは、4 つの使用例で問題を説明するのに十分な例を詳しく説明しません。 🎜
  • 🎜arr.indexOf(‘orange’) は、「orange」が配列の 0 番目の要素であり、インデックスが照合されて返されるため、0 を出力します。 🎜
  • 🎜arr.indexOf(‘o’) は、このメソッドが要素ごとに IndexOf の一致を再度実行しないため、-1 を出力します。 🎜
  • 🎜arr.indexOf('2016') は、このメソッドがすべての配列要素のインデックスを返すのではなく、一致の先頭から一致に達するまでの最初の配列要素の次のリストを返すため、1 を出力します。一致します。 🎜
  • 🎜arr.indexOf(2016) 出力 -1 注: ここでは暗黙的な型変換は行われません。 🎜
🎜 穴が発見されたので、その底に到達したほうが良いでしょう。 MDN 公式 Web サイトにアクセスして確認してください。このトピックに興味のある友人は、Array.prototype.indexOf() に直接ジャンプできます🎜🎜もっと知りたい人のために、ここに公式の説明があります。 🎜
🎜indexOf() は、厳密な等価性 (=== または Triple-equals 演算子で使用されるのと同じ方法) を使用して、searchElement を配列の要素と比較します。🎜
🎜 厳密な等価性であることは一目瞭然です。ここでは が使用されています (===)。同様の判断をされる場合には、より一層ご注意ください。数値は文字列に変換され、文字列は数値に変換されないと誤解しないでください。 🎜🎜まとめ🎜🎜 小さな知識ポイントの蓄積は、詳細な議論の対象ではないため、ここでは、indexOf() の 2 番目のパラメーターの役割については説明していないと思います。ここで String.prototype .indexOf() を見て、上の配列へのリンクと組み合わされた 2 番目のパラメーターを見てください。 🎜🎜上記は JavaScript 配列の IndexOf メソッドの詳細な説明です。さらに関連する内容については、PHP 中国語 Web サイト (www.php.cn) を参照してください。 🎜🎜 🎜
声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。