ホームページ ウェブフロントエンド jsチュートリアル JSのArray.prototype.indexOf拡張による問題と解決策_基礎知識

JSのArray.prototype.indexOf拡張による問題と解決策_基礎知識

May 16, 2016 pm 04:18 PM
array indexof

配列には、indexOf メソッドがないため、配列内の要素のインデックスを見つけるのは面倒です。呼び出しの便宜のために、Array.prototype.indexOf() はプロトタイプ プロトタイプを通じて拡張されています。使いやすい。しかし、配列を走査するときに、このカスタムのindexOfに問題がありました。

コードをコピーします コードは次のとおりです:

Array.prototype.indexOf = function(item) {
for (var i = 0; i if (this[i] == item)

を返します。 }
-1 を返します。 }

を使用する場合に直接

コードをコピーします コードは次のとおりです:
var arr=[1,2,3,4,5]; var インデックス=arr.indexOf(1); //インデックス==0
;

拡張後は非常に快適で使いやすく、調和のとれたシーンを作り出します...

しかし、あるとき、配列要素を走査するときに for..in.. ループが使用され、それが別の問題を引き起こし、調和のとれた雰囲気を壊してしまいました。

コードをコピーします コードは次のとおりです:
var a=["張飛","関羽","劉備","呂布"]; for(var p in a){
document.write(p "=" a[p] "
"); }



本来はこの4人の名前を出力したかったのですが、何が出力されたのでしょうか?
実際の出力は次のとおりです:

コードをコピーします

//2=劉備
//3=呂布
//indexOf=function(item) { for (var i = 0; i


名前を入力するだけでなく、独自の拡張メソッド IndexOf も出力します。しかし、奇妙なことに、Firefox には 4 人の名前しか含まれていないのです。
出力のindexOfは、それ自体で展開できますが、これは理解できます。結局のところ、for..inはオブジェクトのすべてのユーザー定義属性または配列のすべての要素を走査します。

では、Firefox を使用しないのはなぜでしょうか?

後で情報を確認して知りましたが、

Array はすでに JavaScript バージョン 1.6 で Array.indexOf() をサポートしており、私が使用している Firefox はバージョン 3.5 で、すでに JavaScript 1.8 をサポートしています。IndexOf は Array 自体の固有メソッドです。

IE に関しては、IE8 を使用していますが、JavaScript のバージョン 1.3 のみをサポートしています。

つまり、IE8 は、indexOf を「ユーザー定義属性」と見なしますが、Firefox は、それ自体がネイティブにサポートする固有の属性と見なします。

これは本当にそうなのでしょうか?

実験を行って、indexOf の名前を myIndexOf に変更して再試行すると、IE と Firefox の両方で myIndexOf が出力され、前の点が正しいことがわかります。

ここで別の問題が発生します。長い間、indexOf を拡張してきましたが、多くのプロジェクト コードですでにこのメソッドが使用されていますが、配列自体の要素を出力するには for..in を使用する必要があります。自分で延長したくないのですが、ロシアに着いたらどうすればいいですか?

幸いなことに、JavaScript には hasOwnProperty メソッドが用意されています。

その説明を見てください:

コードをコピーします

コードは次のとおりです: Object から派生したすべてのオブジェクトは hasOwnProperty メソッドを継承します。このメソッドは、オブジェクトがそのオブジェクトの直接プロパティとして指定されたプロパティを持っているかどうかを判断するために使用できます。このメソッドは、in 演算子とは異なり、オブジェクトのプロトタイプ チェーン をチェックしません。

説明を見ると、それが私たちが望んでいることです。
for...in... で判断するだけでOKです

コードをコピーします

コードは次のとおりです: if(a.hasOwnProperty(p)){ document.write(p "=" a[p] "
"); }


さらに、インターネットから取得した hasOwnProperty の使用方法の例を次に示します。

コードをコピー

コードは次のとおりです:

関数 Book(タイトル、著者) {
   this.title = タイトル; 
   this.author = 著者; 
  }
   Book.prototype.price = 9.99; 
   Object.prototype.copyright = "herongyang.com"; 
   var myBook = new Book("JavaScript チュートリアル", "Herong Yang"); 
   // 基本プロトタイプ レベルで組み込みプロパティをダンプします
   document.writeln("/nObject.prototype の組み込みプロパティ:"); 
   dumpProperty(Object.prototype, "コンストラクター"); 
   dumpProperty(Object.prototype, "hasOwnProperty"); 
   dumpProperty(Object.prototype, "isPrototypeOf"); 
   dumpProperty(Object.prototype, "toString"); 
   dumpProperty(Object.prototype, "valueOf"); 
   dumpProperty(Object.prototype, "著作権"); 
   // プロトタイプ レベルで組み込みプロパティをダンプします
   document.writeln("/n=================/nBook.prototype の組み込みプロパティ:"); 
   dumpProperty(Book.prototype, "コンストラクター"); 
   dumpProperty(Book.prototype, "hasOwnProperty"); 
   dumpProperty(Book.prototype, "isPrototypeOf"); 
   dumpProperty(Book.prototype, "toString"); 
   dumpProperty(Book.prototype, "valueOf"); 
   dumpProperty(Book.prototype, "著作権"); 
   // オブジェクト レベルで組み込みプロパティをダンプします
   document.writeln("/n==================/nmyBook の組み込みプロパティ:"); 
   dumpProperty(myBook, "コンストラクター"); 
   dumpProperty(myBook, "hasOwnProperty"); 
   dumpProperty(myBook, "isPrototypeOf"); 
   dumpProperty(myBook, "toString"); 
   dumpProperty(myBook, "valueOf"); 
   dumpProperty(myBook, "著作権"); 
function dumpProperty(object, property) {
   var の継承。  
   if (object.hasOwnProperty(property))
      継承 = "ローカル"; 
   それ以外
      継承 = "継承"; 
   document.writeln(プロパティ ": " 継承 ": "
      オブジェクト[プロパティ]); 
}

查看浏览器サポートjavascriptto哪个バージョン:

复制代码代码如下:

http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
http://www.w3.org/1999/xhtml">
ブラウザの JavaScript バージョンのサポート テスト


<スクリプト言語="JavaScript"> //document.write("お使いのブラウザの種類:" navigator.appName "
"); //document.write("ブラウザのバージョン:" navigator.appVersion "
"); //JavaScript1.0をサポートするブラウザはこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.0 をサポートしています
');
<スクリプト言語="JavaScript1.1"> // JavaScript1.1 をサポートするブラウザのみがこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.1 をサポートしています
');
<スクリプト言語="JavaScript1.2"> // JavaScript1.2 をサポートするブラウザのみがこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.2 をサポートしています
');
<スクリプト言語="JavaScript1.3"> //JavaScript1.3をサポートするブラウザはこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.3 をサポートしています
');
<スクリプト言語="JavaScript1.4"> //JavaScript1.4をサポートするブラウザはこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.4 をサポートしています
');
<スクリプト言語="JavaScript1.5"> //JavaScript1.5をサポートするブラウザはこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.5
');
<スクリプト言語="JavaScript1.6"> //JavaScript1.6をサポートするブラウザはこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.6 をサポートしています
');
<スクリプト言語="JavaScript1.7"> //JavaScript1.7をサポートするブラウザはこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.7 をサポートしています
');
<スクリプト言語="JavaScript1.8"> // JavaScript 1.8 をサポートするブラウザのみがこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.8
');
<スクリプト言語="JavaScript1.9"> //JavaScript1.9をサポートするブラウザはこのスクリプトを実行できます
Document.write('このブラウザは JavaScript1.9
');




このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C# の Array.Sort 関数を使用して配列を並べ替える C# の Array.Sort 関数を使用して配列を並べ替える Nov 18, 2023 am 10:37 AM

タイトル: Array.Sort 関数を使用して C# で配列を並べ替える例 本文: C# では、配列は一般的に使用されるデータ構造であり、多くの場合、配列を並べ替える必要があります。 C# には Array クラスが用意されており、このクラスには配列を簡単に並べ替えるための Sort メソッドがあります。この記事では、C# で Array.Sort 関数を使用して配列を並べ替える方法を示し、具体的なコード例を示します。まず、Array.Sort 関数の基本的な使用法を理解する必要があります。 Array.So

PHPのarray_merge_recursive()関数を使用するシンプルで明確な方法 PHPのarray_merge_recursive()関数を使用するシンプルで明確な方法 Jun 27, 2023 pm 01:48 PM

PHP でプログラミングする場合、多くの場合、配列をマージする必要があります。 PHP には、配列のマージを完了するための array_merge() 関数が用意されていますが、配列内に同じキーが存在する場合、この関数は元の値を上書きします。この問題を解決するために、PHP は配列をマージして同じキーの値を保持できる array_merge_recursive() 関数を言語で提供し、プログラム設計をより柔軟にします。配列マージ

PHP で array_combine 関数を使用して 2 つの配列を結合して連想配列にする方法 PHP で array_combine 関数を使用して 2 つの配列を結合して連想配列にする方法 Jun 26, 2023 pm 01:41 PM

PHP には、配列操作をより便利かつ高速にする強力な配列関数が多数あります。 2 つの配列を結合して連想配列にする必要がある場合、PHP の array_combine 関数を使用してこの操作を実行できます。この関数は、実際には、ある配列のキーを別の配列の値として新しい連想配列に結合するために使用されます。次に、PHP の array_combine 関数を使用して 2 つの配列を結合して連想配列にする方法を説明します。 array_comb について学ぶ

PHPのarray_fill()関数の使い方の詳しい説明 PHPのarray_fill()関数の使い方の詳しい説明 Jun 27, 2023 am 08:42 AM

PHP プログラミングにおいて、配列は大量のデータを簡単に処理できる非常に重要なデータ構造です。 PHP は配列関連の関数を多数提供しており、array_fill() はその 1 つです。この記事では、array_fill() 関数の使い方と実際の応用におけるヒントを詳しく紹介します。 1. array_fill() 関数の概要 array_fill() 関数の機能は、同じ値で構成される指定された長さの配列を作成することです。具体的には、この関数の構文は次のとおりです。

Python で Array モジュールを使用する方法 Python で Array モジュールを使用する方法 May 01, 2023 am 09:13 AM

Python の配列モジュールは事前定義された配列であるため、標準のリストよりもメモリ内で使用するスペースがはるかに少なく、追加、削除、インデックス付け、スライスなどの要素レベルの操作を高速に実行することもできます。さらに、配列内のすべての要素は同じ型であるため、平均値、最大値、最小値の計算など、配列が提供する効率的な数値演算関数を使用できます。さらに、配列モジュールは、配列オブジェクトのバイナリ ファイルへの直接の書き込みと読み取りもサポートしているため、大量の数値データを処理する際の効率が向上します。したがって、大量の同種データを処理する必要がある場合は、Python の配列モジュールを使用してコードの実行効率を最適化することを検討してください。配列モジュールを使用するには、まず次のことを行う必要があります。

Java での ArrayStoreException の一般的な原因は何ですか? Java での ArrayStoreException の一般的な原因は何ですか? Jun 25, 2023 am 09:48 AM

Java プログラミングでは、配列は重要なデータ構造です。配列は 1 つの変数に複数の値を格納できます。さらに重要なのは、インデックスを使用して各値にアクセスできることです。ただし、配列を操作しているときに、いくつかの例外が発生する場合があります。そのうちの 1 つは ArrayStoreException です。この記事では、ArrayStoreException 例外の一般的な原因について説明します。 1. 型の不一致 配列の作成時に要素の型を指定する必要があります。互換性のないデータ型を配列に格納しようとすると、

Javaでのindexofメソッドの使用法は何ですか Javaでのindexofメソッドの使用法は何ですか May 17, 2023 pm 02:28 PM

IndexOf メソッド: 注: IndexOf メソッドは、String オブジェクト内の部分文字列の開始位置を示す整数値を返します。部分文字列が見つからない場合は、-1 が返されます。 publicclassIndexOf{publicstaticvoidmain(String[]args){Strings="李宏#王海#林奇#鲁贤#唐梅"; Stringq="#";//検索する文字列 Stringrr="*";//存在しない文字列 inti=0;for(intj=0;j

Indexof と include の違いは何ですか? Indexof と include の違いは何ですか? Nov 24, 2023 pm 01:20 PM

違いは次のとおりです: 1. 戻り値の型が異なる; 2. 受け入れられるパラメータが異なる; 3. NaN を処理する方法が異なる; 4. 大文字と小文字を処理する方法が異なる; 5. 使用できるデータ型が異なる。

See all articles