最全的Javascript編碼規範(推薦),javascript編碼

來源:互聯網
上載者:User

最全的Javascript編碼規範(推薦),javascript編碼

1.嵌入規則

Javascript程式應該盡量放在.js的檔案中,需要調用的時候在頁面中以<script src="filename.js">的形式包含進來。Javascript代碼若不是該頁面專用的,則應盡量避免在頁面中直接編寫Javascript代碼。

2.對齊縮排與換行

a) 縮排

在同一系統中應採用同一種縮排標準,本文提倡縮排大小為4個空格。各編譯器對Tab鍵所代替的空白大小定義不同。建議在設定開發環境時,將編輯器裡的Tab快速鍵重新設定成4個空格。多數編譯器提供了此功能。否則建議按4次空格來進行縮排。

b) 換行

在以下位置必須換行:

每個獨立語句結束後;

if、else、catch、finally、while等關鍵字前;

運算子處換行時,運算子必須在新行的行首。

對於因為單行長度超過限制時產生的換行,參考行長度中的策略進行分隔。

1).字串過長截斷

每行代碼應小於80個字元。若代碼較長應盡量換行,換行應選擇在操作符和標點符號之後,最好是在分號“;”或逗號“,”之後。下一行代碼相對上一行縮排4個空格。這樣可以有效防止複製粘貼引起的代碼缺失等錯誤並增強可讀性。

按一定長度截斷字串,並使用+運算子進行串連。分隔字串盡量按語義進行,如不要在一個完整的名詞中間斷開。特別的,對於HTML片段的拼接,通過縮排,保持和HTML相同的結構:

也可使用數組來進行拼接,相對+運算更容易調整縮排:

2).三元運算子過長

三元運算子由3部分組成,因此其換行應當根據每個部分的長度不同,形成3種不同的情況:

不得出現以下情況:

3).過長的邏輯條件組合

當因為較複雜的邏輯條件組合導致80個字元無法滿足需求時,應當將每個條件獨立一行,邏輯運算子放置在行首進行分隔,或將部分邏輯按邏輯組合進行分隔。最終將右括弧)與左大括弧{放在獨立一行,保證與if內語句塊能容易視覺辨識。如:

4).過長的JSON和數組

如果對象屬性較多導致每個屬性一行佔用空間過大,可以按語義或邏輯進行分組的組織,如:

通過5個一組的分組,將每一行控制在合理的範圍內,並且按邏輯進行了切分。 對於項目較多的數組,也可以採用相同的方法,如:

5).return語句

return如果用運算式的執行作為傳回值,請把運算式和 return 放在同一行中,以免分行符號被誤解析為語句的結束而引起返回錯誤。return 關鍵字後若沒有返回運算式,則返回 undefined。構造器的預設傳回值為 this。

樣本:

3.命名

命名的方法通常有以下幾類:

a).命名法說明

1).camel命名法,形如thisIsAnApple

2).pascal命名法,形如ThisIsAnApple

3).底線命名法,形如this_is_an_apple ·

4).中劃線命名法,形如this-is-an-apple

根據不同類型的內容,必須嚴格採用如下的命名法:

b).變數名:必須使用camel命名法

c).參數名:必須使用camel命名法

d).函數名:必須使用camel命名法

e).方法/屬性:必須使用camel命名法

f).私人(保護)成員:必須以底線_開頭

g).常量名:必須使用全部大寫的底線命名法,如IS_DEBUG_ENABLED

h).類名:必須使用pascal命名法

i).枚舉名:必須使用pascal命名法

j).枚舉的屬性:必須使用全部大寫的底線命名法

k).命名空間:必須使用camel命名法

l).語義:命名同時還需要關注語義,如:

變數名應當使用名詞;

boolean類型的應當使用is、has等起頭,表示其類型;·

函數名應當用動賓短語;

類名應當用名詞。

4.注釋

注釋要盡量簡單,清晰明了。著重注釋的意思,對不太直觀的部分進行註解:

(當然這種直接定義一堆全域變數的做法不推薦)

此外,JavaScript 的注釋有兩種"//" 和"/* .... */",建議"//"用作程式碼注釋,"/* .... */"形式用作對整個程式碼片段的登出,或較正式的聲明中,如函數參數、功能、檔案功能等的描述中:

另:複製粘貼應注意注釋是否與代碼對應。

5.聲明

1).變數的聲明

儘管 JavaScript 語言並不要求在變數使用前先對變數進行聲明。但我們還是應該養成這個好習慣。這樣可以比較容易的檢測出那些未經聲明的變數,避免其變為隱藏的全域變數,造成隱患。

在函數的開始應先用 var 關鍵字聲明函數中要使用的局部變數,注釋變數的功能及代表的含義,且應以字母順序排序。每個變數單獨佔一行,以便添加註釋。這是因為 JavaScript 中只有函數的 {} 表明範圍,用 var 關鍵字聲明的局部變數只在函數內有效,而未經 var 聲明的變數則被視為全域變數。樣本:

用 var 聲明過的變數 valueA 和沒有聲明的變數 valueB 是有區別的。特別需要注意的是,在函數內部用 var 聲明的變數為局部變數,這樣可以有效地避免因局部變數和全域變數同名而產生的錯誤。

2).函數的聲明

函數也應在調用前進行聲明,內建函式應在 var 聲明內部變數的語句之後聲明,可以清晰地表明內部變數和內建函式的範圍。

此外,函數名緊接左括弧'('之間,而右括弧')'和後面的'{'之間要有個空格,以清楚地顯示函數名以其參數部分,和函數體的開始。若函數為匿名 / 無名函數,則 function 關鍵字和左括弧'('之間要留空格,否則可能誤認為該函數的函數名為 function。

內建函式聲明樣本:

從上例的輸出可以看出,inF() 函數僅在 outF() 函數的內部生效,局部變數 innerA 對內建函式的範圍生效。這樣的編碼方式使得變數和函數的範圍變得清晰。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.