js代碼編寫規範

1.嵌入規則
php

Javascript程序應該儘可能放在.js的文件中,須要調用的時候在頁面中以<script src="filename.js">的形式包含進來。Javascript代碼若不是該頁面專用的,則應儘可能避免在頁面中直接編寫Javascript代碼。java

2.對齊縮進與換行canvas

a) 縮進數組

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

b) 換行編輯器

在如下位置必須換行:函數

每一個獨立語句結束後;ui

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

運算符處換行時,運算符必須在新行的行首。 編碼

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

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 對內部函數的做用域生效。這樣的編碼方式使得變量和函數的做用域變得清晰。

相關文章
相關標籤/搜索