ホームページ >ウェブフロントエンド >jsチュートリアル >JavaScript コーディング スタイル ガイドの詳細な紹介
インデント
エディタが自動的に変換するように、タブ = 4 スペースを使用することをお勧めします
セミコロン
を防ぐためにセミコロンを省略しないでください。 ASI (セミコロンを自動的に挿入) エラー
行幅
コードの各行は 80 文字を超えてはなりません。長すぎる場合は、演算子を使用して手動で改行する必要があります
改行
。演算子は前の行の最後にあり、次の行はインデントされます レベル 2 に進み、代入文の場合は、等号の後の部分にも配置する必要があります
空白行
関数宣言と関数宣言、変数宣言と関数宣言、関数内のロジック ブロックの間にはスペースが必要です。行分離
作者の Nicholas は、Flow Control ブロックの先頭に空行を残すことも提案しましたが、例では与えられた内容はあまり明確ではありません
命名
変数名/関数名: Camel (キャメルケース) ルール、最初の単語の最初の文字は小文字、後続の単語の最初の文字は大文字、残りは小文字
コンストラクター: Pascalルール、すべての単語最初の文字は大文字で、残りは小文字です
リテラル
文字列: 二重引用符で囲まれ、改行には [+] 演算子を使用し、エスケープ文字は使用しないでください
値: 小数点を省略しないでください。8 進数は使用しないでください。
Nullの前後のフォーム: null はObjectのプレースホルダーとしてのみ使用し、仮パラメータの検出には使用しないでください。また、初期化されていない変数の検出には使用しないでください。
未定義と初期化されていないものを区別するには、null に初期化する必要がありますNotes
他の開発者が最初を聞く必要なくストーリーの一部に参加できるようにする必要があります。
終わり行: コードを 1 レベルのインデントで区切ります。// の後にスペースが必要です
複数行のコメント
/* * comment line1 * comment line2 */などのEclipse
複数行 空白行を残しますコメントの上
コメントを追加する場所
意味不明なコード
ドキュメントのコメント
/** * 添加指定元素到默认数组 * * @method add * @param {Number} 将要添加的元素 * @return {Boolean} 添加成功/失败 * @throw {TypeError} 参数类型不匹配 */ function add(item){ if(typeof item === "number"){ arr.push(item) } else{ throw new TypeError(); } }3. ステートメントと式
中括弧の配置
推奨される行末スタイル、非推奨 線スタイルステートメントのスペースをブロックする
if の後の括弧の前後にスペースがあります。例:if (expr) { code }switch ステートメント インデントと揃えられます レベル 1 に移動します
「JavaScript
Language Essence」の著者であるダグラス氏は、大文字と小文字の区別はバグを引き起こしやすいため使用すべきではないと考えています(役に立たないと言われています)。一方、ニコラス氏は空行やコメントを使用するだけで十分だと考えていますforループ
ホスティング (プロモーション) によって引き起こされるバグを避けるために、for ループの初期化部分で使用される変数を含め、すべての変数を関数本体の先頭で宣言する必要があります (グローバル変数はブロックされる可能性があります)
for-in ループ
これをトラバーサル配列には使用しないでください。使用するときは、プロトタイププロパティを意図的にトラバースする場合は、コメントを使用して説明する必要があります
変数宣言
関数本体 = 変数宣言 + 関数宣言 + 論理ステートメント。各部分を空行で区切ります
関数宣言
使用する前に最初に宣言してください。関数宣言をif分岐に入れないでください。ブラウザによって理解が異なり、ESは標準
関数呼び出しを提供しません
いいえブロックステートメントとの混同を避けるため、括弧の前後にスペースを入れます
匿名関数即時実行
匿名関数宣言との混乱を避けるために、すぐに実行される匿名関数を括弧で囲みます
厳密モード
オンにしないグローバルスコープで厳密モードをオンにする場合は、関数内でのみオンにします。複数の関数をオンにした場合は、匿名関数を使用して
と等しいかどうかを判断するだけです。 === と !== を使用します
eval
eval() と new Function() を使用せず、匿名関数を使用して setTimeout() と setInterval() を最適化します
基本的なパッケージ化タイプ
Don new Boolean()、new String()、new Number() は使用しないでください
以上がJavaScript コーディング スタイル ガイドの詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。