1. ==
の代わりに === を使用する JavaScript では、===|!== と ==|!= という 2 つの異なる等価演算子が使用され、比較演算では前者を使用することがベスト プラクティスです。
「両側のオペランドの型と値が同じ場合、=== は true を返し、!== は false を返します。」 - JavaScript: Language Essence
ただし、== と!を使用する場合は、 = の場合、型が異なる状況が発生する可能性があります。この場合、オペランドの型は強制的に同じになって比較されるため、期待した結果が得られない可能性があります。
2.Eval == Evil
最初は慣れないかもしれませんが、「eval」を使用すると JavaScript のコンパイラにアクセスできます (注釈: これは非常に強力であるようです)。基本的に、文字列をパラメーターとして eval に渡して実行できます。
これは、スクリプトのパフォーマンスを大幅に低下させるだけでなく (注釈: JIT コンパイラーは文字列の内容を予測できず、プリコンパイルと最適化もできません)、実行されるテキストのペイロードが大きすぎるため、セキュリティ上の大きなリスクももたらします。権威者よ、近づかないでください。
3. 省略しても問題は解決しない可能性があります
技術的には、ほとんどの中括弧とセミコロンを省略できます。ほとんどのブラウザは次のコードを正しく理解します:
if(someVariableExists) x = false
次に、次のようになった場合:
if(someVariableExists) x = false anotherFunctionCall();
上記のコードはこれと同等であると考える人もいるかもしれません:
if(someVariableExists) { x = false; anotherFunctionCall(); }
残念ながら、この理解は間違っています。 。実際の意味は次のとおりです:
if(someVariableExists) { x = false; } anotherFunctionCall();
上記のインデントが中括弧のような錯覚を与えやすいことに気づいたかもしれません。当然のことですが、これはひどい行為であり、何としても避けるべきです。中括弧を省略できるケースは 1 つだけ、つまり 1 行しかない場合ですが、これについては議論の余地があります。
if(2 + 2 === 4) return 'nicely done';
雨の日の計画を立てましょう
おそらく、いつか if ブロックにさらにステートメントを追加する必要が生じるでしょう。この場合、このコードを書き直す必要があります。結論 – 省略は地雷原です。
4. スクリプトをページの下部に配置します
覚えておいてください。主な目的は、ページをできるだけ早くユーザーに表示することです。スクリプトが読み込まれるまで、ブラウザは続行できません。以下のコンテンツをレンダリングします。したがって、ユーザーはより長い待ち時間を余儀なくされることになります。
JS がエフェクトを強化するためだけに使用される場合 (ボタンのクリック イベントなど)、本文の終わりの直前にスクリプトをすぐに配置します。これは間違いなくベストプラクティスです。
5. For ステートメント内での変数の宣言は避けてください
長い for ステートメントを実行する場合は、ステートメント ブロックをできるだけ簡潔にしてください。例:
おっと:
for(var i = 0; i
配列の長さは次のようにする必要があることに注意してください。ループを通過するたびに計算され、「container」要素をクエリするために dom を横断する必要があるたびに、効率は非常に低くなります。
提案:
var container = document.getElementById('container'); for(var i = 0, len = someArray.length; i
6. 文字列を構築する最良の方法
配列やオブジェクトをトラバースする必要があるときは、常に「for」ステートメントについて考える必要はなく、創造的になり、いつでも見つけることができます。より良いもの 例えば、次のようなアプローチがあります。
var arr = ['item 1', 'item 2', 'item 3', ...]; var list = '
- ' + arr.join('
- ') + '
私はあなたの神ではありませんが、信じてください (信じられない場合は自分で試してください) - これが断然最速の方法です!
ネイティブ コード (join() など) を使用すると、システムが内部で何を行うかに関係なく、通常は非ネイティブ コードよりもはるかに高速になります。
7. グローバル変数を減らす
「複数のグローバル変数が 1 つの名前空間の下に編成されている限り、他のアプリケーション、コンポーネント、またはクラス ライブラリとの不正な相互作用の可能性は大幅に減少します 」—Douglas Crockford
var name = 'Jeffrey'; var lastName = 'Way'; function doSomething() {...} console.log(name); // Jeffrey -- 或 window.name// 更好的做法var DudeNameSpace = { name : 'Jeffrey', lastName : 'Way', doSomething : function() {...} } console.log(DudeNameSpace.name); // Jeffrey注: これは単に「DudeNameSpace」という名前ですが、実際には、より合理的な名前が必要です。
8. コードにコメントを追加します 不要に思えますが、信じてください。コードにさらに合理的なコメントを追加してください。数か月後にプロジェクトを振り返ったとき、最初の考えを思い出せないかもしれません。あるいは、同僚の 1 人がコードを変更する必要がある場合はどうすればよいでしょうか?全体として、コードにコメントを追加することは重要な部分です。
// 循环数组,输出每项名字(译者注:这样的注释似乎有点多余吧)for(var i = 0, len = array.length; i <div class="cnblogs_code"></div><p><br>9. プログレッシブエンハンスメントを採用<strong></strong> JavaScript が無効な場合でもスムーズな機能低下を保証します。 「訪問者のほとんどはすでに JavaScript を有効にしているので、心配する必要はありません。」と私たちは常に考えがちですが、これは大きな誤解です。 <br>JavaScript をオフにして、美しいページがどのように見えるかを少し時間を取って確認したことがありますか? (これは、Web Developer ツールをダウンロードすることで簡単に実行できます (翻訳者注: Chrome ユーザーはアプリ ストアでダウンロードし、IE ユーザーはインターネット オプションで設定します))。しかし、これにより Web サイトが壊れる可能性があります。経験則として、JavaScript が無効であることを前提としてサイトを設計し、それに基づいてサイトを徐々に強化していきます。 <br><br><br>10. 文字列パラメーターを「setInterval」または「setTimeout」に渡さないでください。<strong></strong>次のコードを検討してください: <br></p><pre class="brush:php;toolbar:false">setInterval( "document.getElementById('container').innerHTML += 'My new number: ' + i", 3000 );
不仅效率低下,而且这种做法和"eval"如出一辙。从不给setInterval和setTimeout传递字符串作为参数,而是像下面这样传递函数名。
setInterval(someFunction, 3000);
11.不要使用"with"语句
乍一看,"with"语句看起来像一个聪明的主意。基本理念是,它可以为访问深度嵌套对象提供缩写,例如……
with (being.person.man.bodyparts) { arms = true; legs = true; }
而不是像下面这样:
being.person.man.bodyparts.arms = true; being.person.man.bodyparts.legs= true;
不幸的是,经过测试后,发现这时“设置新成员时表现得非常糟糕。作为代替,您应该使用变量,像下面这样。
var o = being.person.man.bodyparts; o.arms = true; o.legs = true;
12.使用{}代替 new Ojbect()
在JavaScript中创建对象的方法有多种。可能是传统的方法是使用"new"加构造函数,像下面这样:
ar o = new Object(); o.name = 'Jeffrey'; o.lastName = 'Way'; o.someFunction = function() { console.log(this.name); }
然而,这种方法的受到的诟病不及实际上多。作为代替,我建议你使用更健壮的对象字面量方法。
更好的做法
var o = { name: 'Jeffrey', lastName = 'Way', someFunction : function() { console.log(this.name); } };
注意,果你只是想创建一个空对象,{}更好。
13.使用[]代替 new Array()
这同样适用于创建一个新的数组。
例如:
var a = new Array(); a[0] = "Joe"; a[1] = 'Plumber';// 更好的做法:var a = ['Joe','Plumber'];
“javascript程序中常见的错误是在需要对象的时候使用数组,而需要数组的时候却使用对象。规则很简单:当属性名是连续的整数时,你应该使用数组。否则,请使用对象”——Douglas Crockford
14.定义多个变量时,省略var关键字,用逗号代替
var someItem = 'some string'; var anotherItem = 'another string'; var oneMoreItem = 'one more string';// 更好的做法var someItem = 'some string', anotherItem = 'another string', oneMoreItem = 'one more string';
应而不言自明。我怀疑这里真的有所提速,但它能是你的代码更清晰。
15.使用Firebug的"timer"功能优化你的代码
在寻找一个快速、简单的方法来确定操作需要多长时间吗?使用Firebug的“timer”功能来记录结果。
function TimeTracker(){ console.time("MyTimer"); for(x=5000; x > 0; x--){} console.timeEnd("MyTimer"); }
以上がJavascript で注意する必要がある詳細は何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

私はあなたの日常的な技術ツールを使用して機能的なマルチテナント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はサーバー側のプログラミングをサポートしており、フルスタック開発に適しています。

JavaScriptは、最新のブラウザにすでに組み込まれているため、インストールを必要としません。開始するには、テキストエディターとブラウザのみが必要です。 1)ブラウザ環境では、タグを介してHTMLファイルを埋め込んで実行します。 2)node.js環境では、node.jsをダウンロードしてインストールした後、コマンドラインを介してJavaScriptファイルを実行します。

Quartzタイマーを使用してタスクをスケジュールする場合、Quartzでタスク通知を事前に送信する方法、タスクの実行時間はCron式によって設定されます。今...


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

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

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

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

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