JavaScript 代碼規范

1、縮進

每一行的層級由 4 個空格組成,避免使用制表符縮進

2、行的長度

每行長度不超過 80 個字符,如果超過,應當在一個運算符(逗號,加號等)后換行。下一行應當增加兩級縮進( 80個空格)

3、運算符的行間距

二元運算符前后必須使用一個空格來保持表達式的簡潔,操作符包括賦值運算符和邏輯運算符

        1 + 2 = 3

4、括號間距

當使用括號時,緊接左括號之后和緊接右括號之前不應該有空格

        if (num > 1)

5、對象直接量

對象直接量應當使用如下格式

  • 起始左花括號應當同表達式保持一行

  • 每個屬性的名值對應當保持一個縮進,第一個屬性應當在左花括號后另起一行

  • 每個屬性的名值對應當使用不含引號的屬性名,其后緊跟一個冒號(之前不含空格) ,而后是值

  • 倘若屬性值是函數類型,函數體應當在屬性名之下另起一行,而且其前后就均保留一個空格

  • 一組相關的屬性前后可以插入空行以提升代碼的可讀性結束的右花括號應當獨占一行

        let obj = {
            // 插入空行
            a: 1,

            fun: function () {

            }
        }

6、注釋

頻繁地使用注釋有助于他人理解你的代碼,如下情況應當使用注釋

  • 代碼晦澀難懂

  • 可能被誤認為錯誤的代碼

  • 必要但并不明顯的針對特定瀏覽器的代碼

  • 對于對象、方法或者屬性,生成文檔是有必要的(使用恰當的文檔注釋)

6.1 單行注釋

單行注釋單行注釋應當用來說明一行或者一組相關的代碼。 單行注釋可能有如下三種使用方式

  • 獨占一行的注釋,用來解釋下一行代碼

  • 在代碼行的尾部注釋,用來解釋它之前的代碼

  • 多行,用來注釋掉一個代碼塊

  • 對于行尾的情況,代碼和注釋間至少一個空格

        // 獨占一行的注釋
        let num = 1; // 代碼行的尾部注釋
6.2 多行注釋

多行注釋應當在代碼需要更多的文字去解釋的時候使用。每個多行注釋應當有如下三行

  • 首行僅僅包含 / 注釋開始,該行不能有其他文件

  • 接下來的行 * 開頭并保持左對齊。這些行可以有文字描述

  • 最后一行以 * 結束并與先前行對齊,也不應再有其他文字

多行注釋應當保持同它描述的代碼一樣的縮進,后續每個 * 后加一個空格

        /*
        * 這是描述
        * 這是描述
        * 這是描述
        */

7、變量聲明

所有變量在使用前都應當事先定義,使用一個var
未初始化值得變量在后面

8、函數聲明

函數應當在使用前提前定義,不是作為對象的方法的函數,應當使用函數聲明的格式( function 聲明)

函數內的函數聲明,應當在 var 聲明后,立即定義

匿名函數的自執行

        (function () {} {})

9、命名

變量和函數命名時要小心。命名應僅限于數字字母字符。某些情況可以使用下劃線。最好不好用美元符號 ($) 和反斜杠 (\)
變量命名采用駝峰式,首字母小寫,每個單詞首字母大寫,變量名的第一個單詞應當是一個名詞(而非動詞)以避免和函數混淆,不要再變量名中使用下劃線。

函數名也使用駝峰,第一個單詞應當是動詞(而非名詞) ,也不要使用下劃線

構造函數才能首字母大寫,名稱應當非動詞開頭

常量(值不會被改變的變量)命名應當是全部大寫,不同單詞用下劃線隔開

        const NUM = 1;

對象的屬性同變量的命名規則相同。對象的方法同函數的命名規則相同,如果屬性或者方法是私有(不希望別人訪司) ,應當在之前加一個下劃

10、嚴格模式

嚴格模式應當僅限在函數內部使用,千萬不要在全局使用。

11、賦值

當給變量賦值時,如果右側時含有比較語句的表達式,需要使用圓括號包裹

       let a = 2;
       let b = 2;
       let num = (a > b) ? a : b;

12、等號運算符

使用 === (嚴格等于)和 ! == (嚴格不相等)代替 == (相等)和 != (不等)來避免弱類型轉換錯誤。

13、三元運算符

三元運算符應當僅僅用在條件賦值語句中,而不要作為 if 的替代品。

       let num = (a > b) ? a : b;

14、語句

14.1 簡單語句

每行最多只包含一條語句。所有簡單的語句都應該以分號結束

14.2 返回語句

返回語句當返回一個值的時候不應當使用圓括號包裹,除非在某些情況下這么做可以讓返回值更容易理解,

14.3 復合語句

復合語句時大括號括起來得語句列表。

  • 括起來的語句應當較符合語句多縮進一個層級

  • 開始的大括號應當在符合語句所在行的末尾;結束的大括號應當獨占一行且同復合語句的開始保持一樣的縮進

  • 當語句是控制結構的一部分時,諸如 if 或者 for 語句,所有的語句都需要用大括號括起來,也包括單個語句。這個約定是讓我們更加方便地添加語句而不用擔心忘記加括號而引起 bug

  • if 一樣的語句的開始的關鍵詞,其后應該緊跟一個空格,起始大括號應當在空格之后

14.3.1 if語句

if 語句應當是下面的格式

       if (判斷條件) {
            // 輸出
       } else {
            // 輸出
       }
14.3.2 for 語句

for 語句的初始化部分不應當有變量聲明

14.3.3 while 語句
14.3.4 switch 語句

如果一個 switch 不包含 default 的情況,應當用注釋代替

        switch (key) {
            case value:
                // code
                break;
        
            case value:
                // code
                break;
        
           // 沒有default
        }

15、留白

在邏輯相關的代碼塊之間添加空行可以提高代碼的可讀性。

兩行空行雙限在如下情況中使用

  • 在不同的源代碼文件之間
  • 在類和接口定義之間

單行空行僅限在如下情況中使用

  • 方法之間

  • 方法中局部變量和第一行語句中間

  • 多行或者單行注釋之前

  • 方法中邏輯代碼塊之間以提升代碼的可讀性

空格應當在如下情況中使用

  • 關鍵詞后跟括號的情況應當用空格隔開
  • 參數列表中逗號之后應當留一個空格
  • 所有的除了點 (.) 之外的二元運算符,其操作數都應當用空格隔開。單目運算符的操作數事件不應該用空白隔開,諸如一元減號,遞增 (++) ,遞減 (-) )。
  • for 語句中的表達式之間應當用空格隔開

16、需要避免的

  • 切勿使用像 String 一類的原始包裝類型創建新的對象。
  • 避免使用eval()
  • 避免使用 with 語句(其實該語句已經被廢除了,所以老夫就不教你們了)

寫在最后:風格這種東西,有很多,就拿縮進來說:

  • jQuery 核心風格指南明確規定使用制表符縮進
  • Daiglas CrockfordJavaScript 代碼規范規定使用 4 個空格字符縮進
  • SproutCore 風格指南規定使用2個空格縮進
  • GoogleJavascript 風格指南規定使用 2 個空格縮進
  • Dojo 編程風格指南規定使用制表符縮進

所以啊,風格很多,大概的了解一下,一切以你所在的團隊風格為準。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,406評論 6 538
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,034評論 3 423
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 177,413評論 0 382
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,449評論 1 316
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,165評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,559評論 1 325
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,606評論 3 444
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,781評論 0 289
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,327評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,084評論 3 356
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,278評論 1 371
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,849評論 5 362
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,495評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,927評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,172評論 1 291
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,010評論 3 396
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,241評論 2 375

推薦閱讀更多精彩內容