JavaScript は、Web 開発分野における「常緑樹」です。 JavaScript フレームワーク (Node.js、React、Angular、Vue など) であっても、ネイティブ JavaScript であっても、それらはすべて非常に大きなファンベースを持っています。最新の JavaScript について話しましょう。ループは常にほとんどのプログラミング言語の重要な部分であり、最新の JavaScript では値を反復またはループするためのさまざまな方法が提供されます。
しかし問題は、どのループまたは反復がニーズに最適であるかを本当に知っているのかということです。 for
ループには、for
、for
(逆順)、for…of
、 など、さまざまなバリエーションがあります。 forEach
、for…in
、for…await
。この記事ではこれらについて説明します。
アプリケーションのパフォーマンスに影響を与える低レベルの間違いを防ぐために、どちらの for ループまたはイテレータがニーズに適しているかを理解します。
どちらのループが速いですか?
答えは実際には次のとおりです: for
(逆順)
私にとって最も驚くべきことは、ローカル コンピューター テスト後、for
(逆順) がすべての for
ループの中で最も高速であるという事実を受け入れる必要がありました。以下に、100 万を超える要素を含む配列に対してループを実行する例を示します。
ステートメント : console.time()
結果の精度は、テストを実行するシステム構成に大きく依存します。精度について詳しくは、こちらをご覧ください。
const million = 1000000; const arr = Array(million); // 注:这是稀疏数组,应该为其指定内容,否则不同方式的循环对其的处理方式会不同: // const arr = [...Array(million)] console.time('⏳'); for (let i = arr.length; i > 0; i--) {} // for(倒序) :- 1.5ms for (let i = 0; i < arr.length; i++) {} // for :- 1.6ms arr.forEach(v => v) // foreach :- 2.1ms for (const v of arr) {} // for...of :- 11.7ms console.timeEnd('⏳');
この結果の理由は非常に単純で、コード内の順方向および逆方向の for
ループにかかる時間はほぼ同じで、その差はわずか 0.1 ミリ秒です。その理由は、for
(逆順) では開始変数 let i = arr.length
を 1 回計算するだけで済むのに対し、順方向 for
ループでは計算が必要になるためです。 is 条件 i<arr.length> は、変数がインクリメントされるたびにチェックされます。この微妙な違いはそれほど重要ではないため、無視してかまいません。 (翻訳者注: データ量が少ない場合、またはコードが時間に依存しない場合は無視できます。ただし、翻訳者のテストによると、データ量が数十億、数千億などのように増大すると、ギャップが大きくなるそうです)は大幅に増加します。アプリケーションのパフォーマンスに対する時間の影響を考慮する必要があります。) </arr.length>
そして forEach
は Array
プロトタイプのメソッドであり、通常の for
ループと比較して、forEach
および for…of
は配列の反復処理に時間がかかります。 (翻訳者注: ただし、for…of
と forEach
はどちらもオブジェクトからデータを取得しますが、プロトタイプはデータを取得しないため、比較できないことに注意してください。)
ループの種類と使用場所
1. For ループ (順方向および逆順)
#おそらく誰もがこの基本的なサイクルをよく知っているはずだと思います。コードを承認された回数実行する必要がある場合は、どこでもfor ループを使用できます。最も基本的な
for ループは最も高速に実行されるため、毎回これを使用する必要があります。いいえ、パフォーマンスだけが唯一の基準ではありません。多くの場合、コードの読みやすさの方が重要です。アプリケーションに適したバリアントを選択しましょう。
2. forEach
forEach では、コールバック関数でオプションのパラメータ
this を使用することもできます。
const things = ['have', 'fun', 'coding']; const callbackFun = (item, idex) => { console.log(`${item} - ${index}`); } things.foreach(callbackFun); /* 输出 have - 0 fun - 1 coding - 2 */
forEach を使用したい場合、JavaScript の短絡演算子 (||、&&...) は使用できない、つまりスキップできないことに注意してください。各ループまたはループの終了。
3. for…of
それES6 (ECMAScript 6) で標準化されています。反復可能なオブジェクト (array
、map
、set
、string
など) に対するループを作成し、優れた利点は優れた可読性です。 <pre class='brush:php;toolbar:false;'>const arr = [3, 5, 7];
const str = &#39;hello&#39;;
for (let i of arr) {
console.log(i); // 输出 3, 5, 7
}
for (let i of str) {
console.log(i); // 输出 &#39;h&#39;, &#39;e&#39;, &#39;l&#39;, &#39;l&#39;, &#39;o&#39;
}</pre>
ループが早期に終了する場合でも、ジェネレーター内で for…of
を使用しないでください。ループを抜けた後、ジェネレーターは閉じられ、それ以上の結果を生成せずに再度反復が試行されます。
4. for 结论 最后,给你一条明智的建议 —— 优先考虑可读性。尤其是当我们开发复杂的结构程序时,更需要这样做。当然,我们也应该专注于性能。尽量避免增添不必要的、多余的花哨代码,因为这有时可能对你的程序性能造成严重影响。祝你编码愉快。 译者注 在译者的实际测试中,发现: 英文原文地址:https://medium.com/javascript-in-plain-english/which-type-of-loop-is-fastest-in-javascript-ec834a0f21b9 原文作者:kushsavani 本文转载自:https://juejin.cn/post/6930973929452339213 译者:霜羽 Hoarfroster 更多编程相关知识,请访问:编程入门!!in
for…in
会在对象的所有可枚举属性上迭代指定的变量。对于每个不同的属性,for…in
语句除返回数字索引外,还将返回用户定义的属性的名称。
因此,在遍历数组时最好使用带有数字索引的传统 for
循环。 因为 for…in
语句还会迭代除数组元素之外的用户定义属性,就算我们修改了数组对象(例如添加自定义属性或方法),依然如此。const details = {firstName: 'john', lastName: 'Doe'};
let fullName = '';
for (let i in details) {
fullName += details[i] + ' '; // fullName: john doe
}
<span style="font-size: 16px;">for…of</span>
和 <span style="font-size: 16px;">for…in</span>
for…of
和 for…in
之间的主要区别是它们迭代的内容。for…in
循环遍历对象的属性,而 for…of
循环遍历可迭代对象的值。let arr= [4, 5, 6];
for (let i in arr) {
console.log(i); // '0', '1', '2'
}
for (let i of arr) {
console.log(i); // '4', '5', '6'
}
for
最快,但可读性比较差foreach
比较快,能够控制内容for...of
比较慢,但香for...in
比较慢,没那么方便
以上がJavaScript で最も速いループのタイプはどれですか?いくつかの for ループの比較の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

さまざまなJavaScriptエンジンは、各エンジンの実装原則と最適化戦略が異なるため、JavaScriptコードを解析および実行するときに異なる効果をもたらします。 1。語彙分析:ソースコードを語彙ユニットに変換します。 2。文法分析:抽象的な構文ツリーを生成します。 3。最適化とコンパイル:JITコンパイラを介してマシンコードを生成します。 4。実行:マシンコードを実行します。 V8エンジンはインスタントコンピレーションと非表示クラスを通じて最適化され、Spidermonkeyはタイプ推論システムを使用して、同じコードで異なるパフォーマンスパフォーマンスをもたらします。

現実世界におけるJavaScriptのアプリケーションには、サーバー側のプログラミング、モバイルアプリケーション開発、モノのインターネット制御が含まれます。 2。モバイルアプリケーションの開発は、ReactNativeを通じて実行され、クロスプラットフォームの展開をサポートします。 3.ハードウェアの相互作用に適したJohnny-Fiveライブラリを介したIoTデバイス制御に使用されます。

私はあなたの日常的な技術ツールを使用して機能的なマルチテナントSaaSアプリケーション(EDTECHアプリ)を作成しましたが、あなたは同じことをすることができます。 まず、マルチテナントSaaSアプリケーションとは何ですか? マルチテナントSaaSアプリケーションを使用すると、Singの複数の顧客にサービスを提供できます

この記事では、許可によって保護されたバックエンドとのフロントエンド統合を示し、next.jsを使用して機能的なedtech SaaSアプリケーションを構築します。 FrontEndはユーザーのアクセス許可を取得してUIの可視性を制御し、APIリクエストがロールベースに付着することを保証します

JavaScriptは、現代のWeb開発のコア言語であり、その多様性と柔軟性に広く使用されています。 1)フロントエンド開発:DOM操作と最新のフレームワーク(React、Vue.JS、Angularなど)を通じて、動的なWebページとシングルページアプリケーションを構築します。 2)サーバー側の開発:node.jsは、非ブロッキングI/Oモデルを使用して、高い並行性とリアルタイムアプリケーションを処理します。 3)モバイルおよびデスクトップアプリケーション開発:クロスプラットフォーム開発は、反応および電子を通じて実現され、開発効率を向上させます。

JavaScriptの最新トレンドには、TypeScriptの台頭、最新のフレームワークとライブラリの人気、WebAssemblyの適用が含まれます。将来の見通しは、より強力なタイプシステム、サーバー側のJavaScriptの開発、人工知能と機械学習の拡大、およびIoTおよびEDGEコンピューティングの可能性をカバーしています。

JavaScriptは現代のWeb開発の基礎であり、その主な機能には、イベント駆動型のプログラミング、動的コンテンツ生成、非同期プログラミングが含まれます。 1)イベント駆動型プログラミングにより、Webページはユーザー操作に応じて動的に変更できます。 2)動的コンテンツ生成により、条件に応じてページコンテンツを調整できます。 3)非同期プログラミングにより、ユーザーインターフェイスがブロックされないようにします。 JavaScriptは、Webインタラクション、シングルページアプリケーション、サーバー側の開発で広く使用されており、ユーザーエクスペリエンスとクロスプラットフォーム開発の柔軟性を大幅に改善しています。

Pythonはデータサイエンスや機械学習により適していますが、JavaScriptはフロントエンドとフルスタックの開発により適しています。 1. Pythonは、簡潔な構文とリッチライブラリエコシステムで知られており、データ分析とWeb開発に適しています。 2。JavaScriptは、フロントエンド開発の中核です。 node.jsはサーバー側のプログラミングをサポートしており、フルスタック開発に適しています。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

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

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

EditPlus 中国語クラック版
サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

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