JS配列のindexOfメソッドについて簡単に説明します。

高洛峰
リリース: 2017-01-14 10:38:01
オリジナル
1349 人が閲覧しました

はじめに

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 は一致しないことを意味します。

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

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

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
ログイン後にコピー

の例では、数値型に対して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) 出力 -1 注: ここでは暗黙的な型変換は行われません。

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

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

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

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

概要

上記がこの記事の全内容です。この記事の内容が皆さんの学習や仕事に少しでも役立つことを願っています。ご質問がある場合は、メッセージを残して連絡してください。

JS 配列の IndexOf メソッドに関するその他の記事については、PHP 中国語 Web サイトに注目してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート