JavaScript 模式(一)

JavaScript 基本技巧


1.盡量少用全局變量

(1)全局變量的說明

  • 變量的作用域是以函數進行管理,函數以外為全局作用域
  • 瀏覽器中以windows作為全局對象本身

(2)隱式產生的全局變量

  • 在函數中不聲明,直接使用的變量,默認為全局變量
  function func(x,y){
        result = x + y; // result 為全局變量
    }
  • 在函數中,使用鏈式賦值
  function func(){
      var a = b = 0; // b為全局變量 a為局部變量
  }
  • 嚴格模式下,在函數中不聲明變量直接用會報錯

(3)全局變量的刪除問題

  • 在全局作用域下,通過var聲明的變量,不能使用delete刪除
  • 在全局作用域下,不通過var聲明,直接使用的變量,可以使用delete刪除
  • 在函數作用域下,不通過var聲明,直接使用的變量,可以使用delete刪除(嚴格模式下不允許使用)

(4)單一var模式

只使用一個var在函數頂部進行變量聲明(最好能賦初值)

   function func(){
       var a = 1,
           b = 2,
           sum = a + b,
           obj = {},
           i,
           j,
           ...
       //函數體
   }
  • 說明:在函數中,默認會將所有變量的聲明語句置頂,因此建議,聲明變量的語句均放置到函數體頂部

2.for循環的說明

  • 遍歷數組的長度需要進行緩存,可以提高速度
  • 變量逐步減至0,可以提高效率,使用如下:
  for(i = length;i--){
    //代碼
  }

3.for-in循環的說明

  • for-in循環用于枚舉對象的所有屬性
  • 為了只把自定義屬性枚舉,而不是把所有內置屬性枚舉出來,需要使用hasOwnProperty()方法進行篩選,如下:
   for(prop in obj){
     if(Object.prototype.hasOwnProperty.call(obj,prop)){
       //代碼
     }
   }

4.不要增加內置的原型

  • 不要為內置對象增加構造函數(Object,Array,Function等)
  • 如果需要為原型添加自定義方法,采用如下方式:
  if(typeof Object.prototype.method !== "function"){
    Object.prototype.method = function () {
      //函數體
    }
  }

5.switch使用模式

  • 每個case與switch縱向排列整齊
  • 每個case語句使用代碼縮進
  • 每個case語句結尾要有一個明確的break語句
  • 避免使用fall-throughs方式
  • 用default作為switch語句的結束

6.避免使用隱式轉換

  • 使用 === ,不要使用 ==

7.避免使用eval()

  • 如果必須使用eval()函數,可以考慮使用new Function() 來代替

8.parseInt()使用

  • 使用時一定不要忽略進制參數

9.編碼約定

(1)縮進

  • 對大括號中的所有代碼執行縮進

(2)大括號

  • 在可選使用大括號的情形下,都使用大括號
  • 為避免解釋器的默認行末加分號的問題,將左大括號與前一個語句放在同一行:
   if(true){
     //TODO
   }

   function(){
     //TODO
   }

(3)空格

使用空格的情況列舉如下:

  • for循環各部分的分號后
  • for循環初始化多個變量時,每個聲明后
  for (var i = 0, max = 10; i < max; i++)
  • 限定數組,每個元素逗號后面
  var array = [1, 2, 3];
  • 對象屬性逗號后,屬性名稱和屬性值之間的冒號后
  var obj = {prop1: value1, prop2: value2};
  • 函數中各參數后
  • 函數聲明的大括號之前
  function func(a, b, c) {
  }
  • 匿名函數表達式之后
  var func = function () {
  }
  • 建議在操作符后 ( + - * = < > === !== += 等)
  • 在大括號之前使用一個空格
  • 在大括號之后,如有else if 或者 while 使用一個空格

命名約定

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

推薦閱讀更多精彩內容