JavaScriptアレイは、多くのプログラミング言語の基本的なデータ構造であり、JavaScriptも例外ではありません。 Arrayの作業の詳細を簡素化するために、JavaScriptは配列拡張機能と呼ばれる一連の機能を提供します。この記事では、さまざまな配列拡張機能とその用途を紹介します。
キーポイント
-
JavaScriptの配列拡張機能は、Arrayの作業の多くの詳細を簡素化する関数であり、複雑なループを関数呼び出しに置き換えることにより、コードの読みやすさを向上させる関数です。それらには、
- 、
forEach()
、map()
、filter()
、every()
、some()
、reduce()
、reduceRight()
、indexOf()
、lastIndexOf()
、 などの方法が含まれます。 -
forEach()
メソッドは、配列内の各要素のコールバック関数を呼び出すことにより、ループとアレイサブスクリプト表記の必要性を排除します。ただし、各要素の関数を呼び出すため、パフォーマンスの劣化を引き起こす可能性があります。 -
map()
forEach()
関数はfilter()
に似ていますが、コールバック関数によって返される値を含む配列を返します。また、 メソッドは値の配列も返しますが、ブール値を返すはずのコールバック関数の返品値に基づいています。 -
reduce()
reduceRight()
メソッドは、配列内の各要素を処理し、単一の値を計算しますが、indexOf()
は同じように動作しますが、配列の最後から始まります。lastIndexOf()
メソッドは、配列内の特定の要素を検索し、 も同じことを行いますが、配列の最後から検索を開始します。
背景
for
ほとんどすべての配列操作は、各配列要素を一度に1つずつ通過することにより実行されます。たとえば、次のコードでは、a
var foo = ["a", "b", "c", "d"]; for (var i = 0, len = foo.length; i < len; i++) { console.log(foo[i]); }
まず、最も重要なことは、前の例が完全に有効なJavaScriptコードであることを理解する必要があります。ただし、複数の複雑なループがある場合、追跡変数は退屈になる可能性があります。配列拡張機能機能を使用すると、ループ全体を関数呼び出しに置き換えることができます。これにより、通常、コードの可読性が向上します。それでは、さまざまな配列拡張機能を見てみましょう。
foreach()
forEach()
多くの配列拡張機能と同様に、メソッドは、パラメーターとして別の関数を受信する関数高次関数です。 forEach()
配列要素を通過する代わりに、コールバック関数は各要素で順番に呼び出されます。コールバック関数は、現在の配列要素、配列インデックス、アレイ自体の3つのパラメーターを受け入れます。次のコードでは、元の例が書き換えられてforEach()
メソッドを使用しています。
var foo = ["a", "b", "c", "d"]; for (var i = 0, len = foo.length; i < len; i++) { console.log(foo[i]); }
forEach()
を使用すると、ループと配列の添え字表記の必要性がなくなることに注意してください。さらに、JavaScriptは関数レベルのスコープを使用するため、forEach()
コールバック関数は、変数名の再利用を可能にする新しいスコープを提供します。唯一の欠点は、配列内の各要素の関数を呼び出すことによって発生するパフォーマンスの損失です。幸いなことに、この損失はしばしば無視できます。また、オプションのパラメーターをコールバック関数の後にforEach()
に渡すことができることに注意してください。存在する場合、2番目のパラメーターは、コールバック関数で使用されるthis
値を定義します。
map()
map()
関数はforEach()
とほぼ同じです。唯一の違いは、コールバック関数によって返された値を含む配列をmap()
に返すことです。たとえば、次のコードではmap()
を使用して、入力配列内の各アイテムの平方根を計算します。次に、結果を配列として返し、表示します。また、アレイ拡張機能は、Math.sqrt()
などの組み込みのJavaScript関数と互換性があることに注意してください。
["a", "b", "c", "d"].forEach(function(element, index, array) { console.log(element); });
filter()
forEach()
やmap()
のように、this
値を受け入れます。そして、map()
のように、filter()
は、コールバック関数の返品値に基づいて値の配列を返します。違いは、filter()
コールバック関数がブール値を返す必要があることです。戻り値がtrueの場合は、結果配列に配列要素を追加します。たとえば、次のコードは、文字xで始まらない元の配列の要素を削除します。この例では、各配列要素に対して正規表現(this
値として渡されます)がテストされます。
var sqrts = [1, 4, 9, 16, 25].map(Math.sqrt); console.log(sqrts); // 显示 "[1, 2, 3, 4, 5]"
すべて()およびsome()
また、every()
およびsome()
関数は、各配列要素でコールバック関数も実行されます。各コールバック関数がtrueを返す場合、every()
はtrueを返し、それ以外の場合はfalse。同様に、少なくとも1つのコールバック関数がtrueを返した場合、some()
はtrueを返します。次の例では、アレイ要素が5未満であるかどうかをテストするためにevery()
およびsome()
を使用します。この場合、最後の要素が5に等しいため、every()
はfalseを返します。ただし、少なくとも1つの要素が5未満であるため、some()
はtrueを返します。インデックスと配列のパラメーターは存在しますが、この例では必要ないため、コールバック関数から省略されていることに注意してください。
["x", "abc", "x1", "xyz"].filter(RegExp.prototype.test, /^x/);
reduce()およびreaduceright()
reduce()
メソッドは、配列内の各要素を処理し(最初から開始)、単一の値を計算します。 reduce()
コールバック関数とオプションの初期値をパラメーターとして好む。初期値が存在しない場合、最初の配列要素が使用されます。 reduce()
コールバック関数は、これまでに見た他のコールバック関数とは異なります。これは、以前の値、現在の値、インデックス、および配列など、4つのパラメーターを受け入れます。 reduce
操作の一般的な例は、配列のすべての値を追加することです。次の例はまさにこれを行います。コールバック関数が初めて呼び出された場合、previous
は1に等しく、current
は2に等しくなります。後続の呼び出しでは、合計が最終値15に蓄積します。
var foo = ["a", "b", "c", "d"]; for (var i = 0, len = foo.length; i < len; i++) { console.log(foo[i]); }プロセスがアレイの終わりから始まり、最初に移動することを除いて、
reduceRight()
メソッドと同じように動作します。 reduce()
indexof()およびlastIndexof()
メソッドは、配列内の特定の要素を検索し、最初の一致のインデックスを返します。一致が見つからない場合、indexOf()
は-1を返します。 indexOf()
最初のパラメーターとして検索する要素をお願いします。 2番目のオプションパラメーターは、検索の開始インデックスを指定します。たとえば、次のコードでは、配列内の文字zの最初の2つの発生を調べます。 2回目の外観を見つけるには、最初の登場を見つけて、その後から再び検索を開始する必要があります。 indexOf()
["a", "b", "c", "d"].forEach(function(element, index, array) { console.log(element); });
メソッドは、配列の端から検索を開始することを除いて、まったく同じように機能します。 lastIndexOf()
結論
配列拡張機能関数を使用して、簡潔でクリアコードを記述します。残念ながら、一部の古いブラウザはこれらの方法をサポートしていません。ただし、これらのメソッドを検出して、)をチェックできます。メソッドが欠落している場合は、独自の実装を簡単に提供できます。 Array.prototype
Array.prototype.forEach
以上がJavaScriptのアレイエクストラの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

JavaScriptは、Webページのインタラクティブ性とダイナミズムを向上させるため、現代のWebサイトの中心にあります。 1)ページを更新せずにコンテンツを変更できます。2)Domapiを介してWebページを操作する、3)アニメーションやドラッグアンドドロップなどの複雑なインタラクティブ効果、4)ユーザーエクスペリエンスを改善するためのパフォーマンスとベストプラクティスを最適化します。

CおよびJavaScriptは、WebAssemblyを介して相互運用性を実現します。 1)CコードはWebAssemblyモジュールにコンパイルされ、JavaScript環境に導入され、コンピューティングパワーが強化されます。 2)ゲーム開発では、Cは物理エンジンとグラフィックスレンダリングを処理し、JavaScriptはゲームロジックとユーザーインターフェイスを担当します。

JavaScriptは、Webサイト、モバイルアプリケーション、デスクトップアプリケーション、サーバー側のプログラミングで広く使用されています。 1)Webサイト開発では、JavaScriptはHTMLおよびCSSと一緒にDOMを運用して、JQueryやReactなどのフレームワークをサポートします。 2)ReactNativeおよびIonicを通じて、JavaScriptはクロスプラットフォームモバイルアプリケーションを開発するために使用されます。 3)電子フレームワークにより、JavaScriptはデスクトップアプリケーションを構築できます。 4)node.jsを使用すると、JavaScriptがサーバー側で実行され、高い並行リクエストをサポートします。

Pythonはデータサイエンスと自動化により適していますが、JavaScriptはフロントエンドとフルスタックの開発により適しています。 1. Pythonは、データ処理とモデリングのためにNumpyやPandasなどのライブラリを使用して、データサイエンスと機械学習でうまく機能します。 2。Pythonは、自動化とスクリプトにおいて簡潔で効率的です。 3. JavaScriptはフロントエンド開発に不可欠であり、動的なWebページと単一ページアプリケーションの構築に使用されます。 4. JavaScriptは、node.jsを通じてバックエンド開発において役割を果たし、フルスタック開発をサポートします。

CとCは、主に通訳者とJITコンパイラを実装するために使用されるJavaScriptエンジンで重要な役割を果たします。 1)cは、JavaScriptソースコードを解析し、抽象的な構文ツリーを生成するために使用されます。 2)Cは、Bytecodeの生成と実行を担当します。 3)Cは、JITコンパイラを実装し、実行時にホットスポットコードを最適化およびコンパイルし、JavaScriptの実行効率を大幅に改善します。

現実世界でのJavaScriptのアプリケーションには、フロントエンドとバックエンドの開発が含まれます。 1)DOM操作とイベント処理を含むTODOリストアプリケーションを構築して、フロントエンドアプリケーションを表示します。 2)node.jsを介してRestfulapiを構築し、バックエンドアプリケーションをデモンストレーションします。

Web開発におけるJavaScriptの主な用途には、クライアントの相互作用、フォーム検証、非同期通信が含まれます。 1)DOM操作による動的なコンテンツの更新とユーザーインタラクション。 2)ユーザーエクスペリエンスを改善するためにデータを提出する前に、クライアントの検証が実行されます。 3)サーバーとのリフレッシュレス通信は、AJAXテクノロジーを通じて達成されます。

JavaScriptエンジンが内部的にどのように機能するかを理解することは、開発者にとってより効率的なコードの作成とパフォーマンスのボトルネックと最適化戦略の理解に役立つためです。 1)エンジンのワークフローには、3つの段階が含まれます。解析、コンパイル、実行。 2)実行プロセス中、エンジンはインラインキャッシュや非表示クラスなどの動的最適化を実行します。 3)ベストプラクティスには、グローバル変数の避け、ループの最適化、constとletsの使用、閉鎖の過度の使用の回避が含まれます。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

AtomエディタMac版ダウンロード
最も人気のあるオープンソースエディター

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

WebStorm Mac版
便利なJavaScript開発ツール

ホットトピック









