Javascript で注意する必要がある詳細は何ですか?
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 < someArray.length; i++) { var container = document.getElementById('container'); container.innerHtml += 'my number: ' + i; console.log(i); }
配列の長さは次のようにする必要があることに注意してください。ループを通過するたびに計算され、「container」要素をクエリするために dom を横断する必要があるたびに、効率は非常に低くなります。
提案:
var container = document.getElementById('container'); for(var i = 0, len = someArray.length; i < len; i++) { container.innerHtml += 'my number: ' + i; console.log(i); }
6. 文字列を構築する最良の方法
配列やオブジェクトをトラバースする必要があるときは、常に「for」ステートメントについて考える必要はなく、創造的になり、いつでも見つけることができます。より良いもの 例えば、次のようなアプローチがあります。
var arr = ['item 1', 'item 2', 'item 3', ...]; var list = '<ul><li>' + arr.join('</li><li>') + '</li></ul>';
私はあなたの神ではありませんが、信じてください (信じられない場合は自分で試してください) - これが断然最速の方法です!
ネイティブ コード (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
8. コードにコメントを追加します 不要に思えますが、信じてください。コードにさらに合理的なコメントを追加してください。数か月後にプロジェクトを振り返ったとき、最初の考えを思い出せないかもしれません。あるいは、同僚の 1 人がコードを変更する必要がある場合はどうすればよいでしょうか?全体として、コードにコメントを追加することは重要な部分です。
// 循环数组,输出每项名字(译者注:这样的注释似乎有点多余吧)for(var i = 0, len = array.length; i < len; i++) { console.log(array[i]); }
9. プログレッシブエンハンスメントを採用 JavaScript が無効な場合でもスムーズな機能低下を保証します。 「訪問者のほとんどはすでに JavaScript を有効にしているので、心配する必要はありません。」と私たちは常に考えがちですが、これは大きな誤解です。
JavaScript をオフにして、美しいページがどのように見えるかを少し時間を取って確認したことがありますか? (これは、Web Developer ツールをダウンロードすることで簡単に実行できます (翻訳者注: Chrome ユーザーはアプリ ストアでダウンロードし、IE ユーザーはインターネット オプションで設定します))。しかし、これにより Web サイトが壊れる可能性があります。経験則として、JavaScript が無効であることを前提としてサイトを設計し、それに基づいてサイトを徐々に強化していきます。
10. 文字列パラメーターを「setInterval」または「setTimeout」に渡さないでください。次のコードを検討してください:
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 サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

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

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

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

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法 はじめに: 技術の継続的な発展により、音声認識技術は人工知能の分野の重要な部分になりました。 WebSocket と JavaScript をベースとしたオンライン音声認識システムは、低遅延、リアルタイム、クロスプラットフォームという特徴があり、広く使用されるソリューションとなっています。この記事では、WebSocket と JavaScript を使用してオンライン音声認識システムを実装する方法を紹介します。

顔の検出および認識テクノロジーは、すでに比較的成熟しており、広く使用されているテクノロジーです。現在、最も広く使用されているインターネット アプリケーション言語は JS ですが、Web フロントエンドでの顔検出と認識の実装には、バックエンドの顔認識と比較して利点と欠点があります。利点としては、ネットワーク インタラクションの削減とリアルタイム認識により、ユーザーの待ち時間が大幅に短縮され、ユーザー エクスペリエンスが向上することが挙げられます。欠点としては、モデル サイズによって制限されるため、精度も制限されることが挙げられます。 js を使用して Web 上に顔検出を実装するにはどうすればよいですか? Web 上で顔認識を実装するには、JavaScript、HTML、CSS、WebRTC など、関連するプログラミング言語とテクノロジに精通している必要があります。同時に、関連するコンピューター ビジョンと人工知能テクノロジーを習得する必要もあります。 Web 側の設計により、次の点に注意してください。

WebSocketとJavaScript:リアルタイム監視システムを実現するためのキーテクノロジー はじめに: インターネット技術の急速な発展に伴い、リアルタイム監視システムは様々な分野で広く利用されています。リアルタイム監視を実現するための重要なテクノロジーの 1 つは、WebSocket と JavaScript の組み合わせです。この記事では、リアルタイム監視システムにおける WebSocket と JavaScript のアプリケーションを紹介し、コード例を示し、その実装原理を詳しく説明します。 1.WebSocketテクノロジー

株式分析に必須のツール: PHP および JS でローソク足チャートを描画する手順を学びます。特定のコード例が必要です。インターネットとテクノロジーの急速な発展に伴い、株式取引は多くの投資家にとって重要な方法の 1 つになりました。株価分析は投資家の意思決定の重要な部分であり、ローソク足チャートはテクニカル分析で広く使用されています。 PHP と JS を使用してローソク足チャートを描画する方法を学ぶと、投資家がより適切な意思決定を行うのに役立つ、より直感的な情報が得られます。ローソク足チャートとは、株価をローソク足の形で表示するテクニカルチャートです。株価を示しています

JavaScript と WebSocket を使用してリアルタイム オンライン注文システムを実装する方法の紹介: インターネットの普及とテクノロジーの進歩に伴い、ますます多くのレストランがオンライン注文サービスを提供し始めています。リアルタイムのオンライン注文システムを実装するには、JavaScript と WebSocket テクノロジを使用できます。 WebSocket は、TCP プロトコルをベースとした全二重通信プロトコルで、クライアントとサーバー間のリアルタイム双方向通信を実現します。リアルタイムオンラインオーダーシステムにおいて、ユーザーが料理を選択して注文するとき

JavaScript と WebSocket: 効率的なリアルタイム天気予報システムの構築 はじめに: 今日、天気予報の精度は日常生活と意思決定にとって非常に重要です。テクノロジーの発展に伴い、リアルタイムで気象データを取得することで、より正確で信頼性の高い天気予報を提供できるようになりました。この記事では、JavaScript と WebSocket テクノロジを使用して効率的なリアルタイム天気予報システムを構築する方法を学びます。この記事では、具体的なコード例を通じて実装プロセスを説明します。私たちは

JavaScript チュートリアル: HTTP ステータス コードを取得する方法、特定のコード例が必要です 序文: Web 開発では、サーバーとのデータ対話が頻繁に発生します。サーバーと通信するとき、多くの場合、返された HTTP ステータス コードを取得して操作が成功したかどうかを判断し、さまざまなステータス コードに基づいて対応する処理を実行する必要があります。この記事では、JavaScript を使用して HTTP ステータス コードを取得する方法を説明し、いくつかの実用的なコード例を示します。 XMLHttpRequestの使用

インターネット金融の急速な発展に伴い、株式投資を選択する人がますます増えています。株式取引では、ローソク足チャートは一般的に使用されるテクニカル分析手法であり、株価の変化傾向を示し、投資家がより正確な意思決定を行うのに役立ちます。この記事では、PHP と JS の開発スキルを紹介し、株価ローソク足チャートの描画方法を読者に理解してもらい、具体的なコード例を示します。 1. 株のローソク足チャートを理解する 株のローソク足チャートの描き方を紹介する前に、まずローソク足チャートとは何かを理解する必要があります。ローソク足チャートは日本人が開発した
