精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

編寫高質量 JS 變量的5種優秀做法

開發 前端
變量無處不在,即使我們在寫一個小的函數,或者一個應用程序:我們總是先聲明,分配和使用變量。編寫好的變量可提高代碼的可讀性和易維護性。

[[373383]]

本文已經原作者Shadeed 授權翻譯。

變量無處不在,即使我們在寫一個小的函數,或者一個應用程序:我們總是先聲明,分配和使用變量。編寫好的變量可提高代碼的可讀性和易維護性。

在本文中,主要介紹 5種有關在 JavaScript 中聲明和使用變量的最佳做法。

1.首選 const,再 let

我使用const或let聲明變量,兩者之間的主要區別是const變量需要一個初始值,并且一旦初始化就無法重新分配其值。

另一方面,let聲明不需要初始值,我們可以多次重新分配其值。

  1. // const 需要初始化 
  2. const pi = 3.14; 
  3. // 不能重新分配const 
  4. pi = 4.89; // throws "TypeError: Assignment to constant variable" 

另一方面,let聲明不需要初始值,我們可以多次重新分配其值。

  1. // let 初始化是可選的 
  2. let result; 
  3. // let can be reassigned 
  4. result = 14; 
  5. result = result * 2; 

選擇變量的聲明類型時的一個好習慣是首選const,否則使用let。

  1. function myBigFunction(param1, param2) { 
  2.   /* lots of stuff... */ 
  3.  
  4.   const result = otherFunction(param1); 
  5.  
  6.   /* lots of stuff... */ 
  7.   return something; 

例如,如果我們正在查看函數體,并看到const result = ...聲明:

  1. function myBigFunction(param1, param2) { 
  2.   /* lots of stuff... */ 
  3.  
  4.   const result = otherFunction(param1); 
  5.  
  6.   /* lots of stuff... */ 
  7.   return something; 

不知道myBigFunction()內部會發生什么, 我們可以得出結論,result 變量只分配了一次,聲明之后是只讀的。

在其他情況下,如果必須在執行過程中多次重新分配變量,則可以使用let聲明。

2.最小化變量的范圍

變量存在于它們所創建的作用域內。代碼塊和函數體為const和let變量創建一個作用域。提高變量可讀性的一個好習慣是將變量保持在最小作用域內。

例如,以下函數是二進制搜索算法的實現:

  1. function binarySearch(array, search) { 
  2.   let middle; 
  3.   let middleItem; 
  4.   let left = 0; 
  5.   let right = array.length - 1; 
  6.  
  7.   while(left <= right) { 
  8.     middle = Math.floor((left + right) / 2); 
  9.     middleItem = array[middle]; 
  10.     if (middleItem === search) {  
  11.       return true;  
  12.     } 
  13.     if (middleItem < search) {  
  14.       left = middle + 1;  
  15.     } else { 
  16.       right = middle - 1;  
  17.     } 
  18.   } 
  19.   return false
  20.  
  21. binarySearch([2, 5, 7, 9], 7); // => true 
  22. binarySearch([2, 5, 7, 9], 1); // => false 

middle和middleItem變量在函數體的開頭聲明。因此,這些變量在binarySearch()函數體創建的整個作用域內都是可用的。

middle變量保留二進制搜索的中間索引,而middleItem變量保留二進制搜索的中間索引。

但是,middle和middleItem變量只在while循環代碼塊中使用。所以為什么不直接在while代碼塊中聲明這些變量呢?

  1. function binarySearch(array, search) { 
  2.   let left = 0; 
  3.   let right = array.length - 1; 
  4.  
  5.   while(left <= right) { 
  6.     const middle = Math.floor((left + right) / 2); 
  7.     const middleItem = array[middle]; 
  8.     if (middleItem === search) { 
  9.       return true;  
  10.     } 
  11.     if (middleItem < search) { 
  12.       left = middle + 1;  
  13.     } else { 
  14.       right = middle - 1;  
  15.     } 
  16.   } 
  17.   return false

現在,middle和middleItem變量僅存在于使用變量的作用域。他們的生命周期和生命周期極短,因此更容易推斷其作用。

3.在接近位置聲明變量

我強烈希望在函數主體的頂部聲明所有變量,尤其是在函數較大的情況下。不幸的是,這種做法的缺點是使我在函數中使用的意圖變量變得混亂。

盡量在接近使用位置的地方聲明變量。這樣,我們就不用猜了:嘿,我看到了這里聲明的變量,但是它在哪里被使用了。

假設我們有一個函數,該函數的主體中包含很多語句。我們可以在函數的開頭聲明并初始化變量結果,但是只能在return語句中使用result:

  1. function myBigFunction(param1, param2) { 
  2.   const result = otherFunction(param1); 
  3.   let something; 
  4.  
  5.   /* 
  6.    * calculate something...  
  7.    */ 
  8.  
  9.   return something + result; 

問題在于result 變量在開頭聲明,但僅在結尾使用,沒有足夠的理由在開始時聲明該變量。

讓我們通過將result 變量聲明移到return語句之前來改進這個函數

  1. function myBigFunction(param1, param2) { 
  2.   let something; 
  3.  
  4.   /*  
  5.    * calculate something...  
  6.    */ 
  7.  
  8.   const result = otherFunction(param1); 
  9.   return something + result; 

現在,result變量在函數中有了它的正確位置。

4.好的命名意味著易于閱讀

從良好的變量命名的眾多規則中,我區分出兩個重要的規則。

第一個很簡單:使用駝峰命名為變量取名,并且在命名所有變量時保持一致。

  1. const message = 'Hello'
  2. const isLoading = true
  3. let count 

有特殊含義的數字或字符串,變量命名通常是大寫的,在單詞之間加下劃線,以區別于常規變量

  1. const SECONDS_IN_MINUTE = 60; 
  2. const GRAPHQL_URI = 'http://site.com/graphql'

第二條規則,在變量命名中,我認為這是最重要的:變量名稱應明確無歧義地指出哪些數據保存了該變量。

以下是一些很好的變量命名示例:

  1. let message = 'Hello'
  2. let isLoading = true
  3. let count

message 名稱表示此變量包含某種消息,很可能是字符串。

isLoading相同,布爾值指示加載是否在進行中。

count變量表示保存一些計數結果的數字類型變量。

選擇一個明確表明其角色的變量名。

舉個例子,這樣就能看出區別了。假設看到了這樣一個函數:

  1. function salary(ws, r) { 
  2.   let t = 0; 
  3.   for (w of ws) { 
  4.     t += w * r; 
  5.   } 
  6.   return t; 

你能總結出這個函數的作用嗎?像ws、r、t、w這樣的變量名幾乎沒有說明它們的意圖。

相反,相同的函數,但使用了解釋性變量命名

  1. function calculateTotalSalary(weeksHours, ratePerHour) { 
  2.   let totalSalary = 0; 
  3.   for (const weekHours of weeksHours) { 
  4.     const weeklySalary = weekHours * ratePerHour; 
  5.     totalSalary += weeklySalary; 
  6.   } 
  7.   return totalSalary; 

該代碼清楚地說明了它的作用。這就是良好命名的力量。

5. 引入中間變量

我比較少注釋代碼。我更喜歡編寫代碼即解釋的風格,通過對變量、屬性、函數和類的良好命名來表達意圖。

編寫自文檔代碼的一個好習慣是引入中間變量。在處理長表達式時很有用。

考慮以下表達式:

  1. const sum = val1 * val2 + val3 / val4; 

我們引入兩個中間變量,增強長表達式的可讀性:

  1. const multiplication = val1 * val2; 
  2. const division       = val3 / val4; 
  3.  
  4. const sum = multiplication + division; 

另外,讓我們回顧一下二進制搜索實現算法:

  1. function binarySearch(array, search) { 
  2.   let left = 0; 
  3.   let right = array.length - 1; 
  4.  
  5.   while(left <= right) { 
  6.     const middle = Math.floor((left + right) / 2); 
  7.     const middleItem = array[middle]; 
  8.     if (middleItem === search) { 
  9.       return true;  
  10.     } 
  11.     if (middleItem < search) { 
  12.       left = middle + 1;  
  13.     } else { 
  14.       right = middle - 1;  
  15.     } 
  16.   } 
  17.   return false

這里middleItem是一個保存中間項目的中間變量。使用中間變量MiddleItem而不是直接使用項目訪問器array [middle]可讀性更好。

與缺少middleItem解釋變量的函數版本進行比較:

  1. function binarySearch(array, search) { 
  2.   let left = 0; 
  3.   let right = array.length - 1; 
  4.  
  5.   while(left <= right) { 
  6.     const middle = Math.floor((left + right) / 2); 
  7.     if (array[middle] === search) { 
  8.       return true;  
  9.     } 
  10.     if (array[middle] < search) { 
  11.       left = middle + 1;  
  12.     } else { 
  13.       right = middle - 1;  
  14.     } 
  15.   } 
  16.   return false

這個版本,沒有解釋變量,可讀性就比較差。

6. 總結

變量無處不在,我們總是先聲明,分配和使用變量。

在 JS 中使用變量時,第一個好的做法是使用const,否則使用let

試著保持變量的作用域盡可能小。同樣,將變量聲明往盡可能靠近使用位置。

不要低估好的命名的重要性。始終遵循這樣的規則:變量名應該清晰而明確地表示保存變量的數據。不要害怕使用較長的名字:最好是清晰而不是簡潔。

最后,少使用注釋,多寫寫代碼即的效果 。在高度復雜的地方,我更喜歡引入中間變量。

 

作者:Shadeed 譯者:前端小智 來源:dmitripavlutin原文:https://dmitripavlutin.com/javascript-variables-practices/

本文轉載自微信公眾號「大遷世界」,可以通過以下二維碼關注。轉載本文請聯系大遷世界公眾號。

 

責任編輯:武曉燕 來源: 大遷世界
相關推薦

2020-02-14 09:39:40

箭頭函數語法運算符

2020-02-14 14:35:01

編程語言PythonJava

2023-07-06 14:51:30

開發高質量軟件

2011-03-04 10:11:09

JavascriptAPI

2012-09-13 10:44:18

Python代碼

2020-03-12 14:03:59

工具代碼開發

2015-08-25 08:42:36

高質量代碼命名

2015-08-25 08:29:11

編寫高質量命名

2011-12-29 15:02:27

JavaScript

2024-03-07 11:39:24

HadolintDockerfile工具

2017-07-14 09:54:47

代碼函數程序

2015-07-13 10:48:44

OC代碼程序員

2023-10-31 16:22:31

代碼質量軟件開發Java

2011-04-07 09:18:59

MySQL語法

2023-03-09 15:05:46

HTMLWeb 開發SEO

2010-03-01 14:31:04

Java

2021-08-08 14:26:24

SQL數據庫開發

2011-04-01 09:13:19

VB程序員

2011-05-31 13:43:46

外鏈

2010-05-24 14:48:56

MySQL語法
點贊
收藏

51CTO技術棧公眾號

无码人妻精品一区二区蜜桃百度| 成人乱色短篇合集| 自拍偷拍亚洲天堂| 福利精品在线| 亚洲激情在线播放| 噜噜噜噜噜久久久久久91| 中文字幕免费播放| 欧美日韩亚洲一区| 一区二区日韩精品| 91精产国品一二三| 电影天堂国产精品| 亚洲一区二区三区四区在线观看 | 香蕉久久99| 欧美日韩中文字幕精品| 免费拍拍拍网站| av影片免费在线观看| 国产成人免费在线| 国产日本欧美一区二区三区| 国产在线欧美在线| 色97色成人| 精品调教chinesegay| www.日本久久| 激情中国色综合| 天天综合色天天综合色h| 一区二区三区欧美在线| 日本啊v在线| 丁香另类激情小说| 91精品久久久久久久久久久| 国产成人在线免费视频| 中文字幕免费精品| 国产亚洲欧美日韩美女| 91玉足脚交白嫩脚丫| 精品一区二区三区四区五区 | 久久不见久久见国语| 欧美一级搡bbbb搡bbbb| 午夜宅男在线视频| 视频二区不卡| 精品欧美激情精品一区| 欧美日韩激情四射| 日本电影在线观看网站| 久久午夜老司机| 精品国产乱码久久久久软件| www.日韩高清| 国内成人免费视频| 国产日韩在线视频| 丰满人妻一区二区三区四区| 性8sex亚洲区入口| 7777精品视频| 亚洲黄色三级视频| 亚洲国产精品一区制服丝袜| 欧美国产日韩一区二区在线观看| 糖心vlog免费在线观看| 久久在线视频免费观看| 日韩在线免费视频| 精品一区二区在线观看视频| 第一会所亚洲原创| 亚洲精品资源美女情侣酒店| 97香蕉碰碰人妻国产欧美| 成人高潮a毛片免费观看网站| 日韩一区二区精品葵司在线 | 久久久91麻豆精品国产一区| 欧美精品日韩一本| 亚洲va在线va天堂va偷拍| 国产精品原创视频| 欧美嫩在线观看| 涩多多在线观看| 免费精品一区| 精品福利视频一区二区三区| 久久久久亚洲AV成人无码国产| 精品亚洲自拍| 亚洲天堂开心观看| 欧洲性xxxx| 外国成人免费视频| 色综合视频一区中文字幕| 精品一区二区三区人妻| 国产亚洲毛片在线| 国产精国产精品| 91麻豆一区二区| 国产成人亚洲综合a∨婷婷图片| 国产精品免费一区二区三区四区| 亚洲欧美丝袜中文综合| 国产亚洲欧美在线| 伊人久久大香线蕉精品| 制服丝袜在线播放| 黑丝美女久久久| 日本肉体xxxx裸体xxx免费| 国产色99精品9i| 亚洲第一视频在线观看| 亚洲成人黄色av| 中文精品电影| 欧洲亚洲在线视频| 97视频免费在线| 成人动漫精品一区二区| 日韩免费av电影| 中文字幕有码在线观看| 日韩欧美在线视频| 亚洲网中文字幕| 乱亲女h秽乱长久久久| 这里只有视频精品| 久久免费公开视频| 日本视频在线一区| 国产激情一区二区三区在线观看| 毛片在线能看| 亚洲日本在线天堂| av免费在线播放网站| 91麻豆精品| 亚洲人线精品午夜| 免费又黄又爽又色的视频| 巨乳诱惑日韩免费av| 91免费视频网站| 深夜福利视频在线免费观看| 专区另类欧美日韩| 不卡影院一区二区| 成人h动漫免费观看网站| 日韩一区二区三区国产| 一区二区三区视频免费看| 母乳一区在线观看| 成人精品久久一区二区三区| 天天操天天爱天天干| 亚洲免费在线播放| 黄色在线视频网| 亚洲自拍电影| 国产综合在线视频| 国产特级aaaaaa大片| 国产精品视频麻豆| 免费日韩视频在线观看| 国产福利资源一区| 欧美另类精品xxxx孕妇| 91片黄在线观看喷潮| 国产欧美日韩激情| 免费黄色特级片| 日韩伦理一区二区三区| 欧美激情一区二区三区在线视频观看| 中文字幕理论片| 中文字幕乱码亚洲精品一区| 欧美精品第三页| 日韩三级av| 国内精品久久久久伊人av| 97超碰人人草| 亚洲视频一二三| www.夜夜爽| 99久久久久久中文字幕一区| 国产精品视频公开费视频| 二人午夜免费观看在线视频| 色综合激情五月| 黄瓜视频污在线观看| 免费在线亚洲欧美| 久久精品中文字幕一区二区三区 | 国产一区久久| 99视频国产精品免费观看| a毛片在线观看| 欧美一区二区三区在线电影| 538精品在线视频| 国产激情一区二区三区| www.国产亚洲| 第四色在线一区二区| 高清视频欧美一级| 色鬼7777久久| 在线亚洲欧美专区二区| 黄色av免费播放| 久久99蜜桃精品| 久久精品在线免费视频| 澳门精品久久国产| 欧美自拍大量在线观看| 国产三级在线观看| 欧美人牲a欧美精品| 老司机成人免费视频| 国产一区二区不卡在线| 国产美女在线一区| 亚洲影院天堂中文av色| 国产精品免费久久久久影院| 国产淫片在线观看| 亚洲成人动漫在线播放| 黄色污污网站在线观看| 中文字幕一区二区三区av| 国产精品中文久久久久久| 在线亚洲成人| 亚洲精蜜桃久在线| 精品一区二区三区中文字幕| 国模视频一区二区三区| 成年午夜在线| 欧美大胆一级视频| 一级片在线观看免费| 中文字幕一区二区三区四区| 国产精品一区二区无码对白| 噜噜噜久久亚洲精品国产品小说| 亚洲午夜激情| 男人的天堂久久| 国产欧美一区二区三区久久人妖| 久久久123| 伊人久久久久久久久久久| 国产色综合视频| 欧美日韩国产一区二区三区| 免费看的黄色录像| 成人毛片在线观看| 99热一区二区| 国产精品亚洲产品| 好吊色视频988gao在线观看| 国产精品午夜一区二区三区| 99久久精品久久久久久ai换脸| 另类专区亚洲| 欧美精品18videos性欧| 国产粉嫩一区二区三区在线观看| 日韩欧美国产wwwww| 成人小视频在线播放| 亚洲第一综合色| 极品美妇后花庭翘臀娇吟小说| av电影一区二区| 性久久久久久久久久久久久久| 亚洲制服少妇| 日韩精品一区二区三区四| 黑人操亚洲人| 久久久水蜜桃| 91精品导航| 成人做爰www免费看视频网站| 日本在线播放一二三区| 精品中文字幕在线| 一级日本在线| 亚洲视频在线观看视频| 蜜桃久久一区二区三区| 91精品国产综合久久福利软件| 精品国产乱子伦| 欧美性20hd另类| 一级aaa毛片| 一区二区三区影院| 日韩一级片大全| 国产精品国产三级国产普通话99 | 亚洲午夜在线| ijzzijzzij亚洲大全| 欧美一级精品| 日韩一本精品| 免费视频一区三区| 久久天天狠狠| 欧美一级全黄| 国产丝袜不卡| 欧美中文一区| 久久波多野结衣| 牛牛影视久久网| 国产日韩久久| 久久影视三级福利片| 国产精品国产三级欧美二区 | 香蕉伊大人中文在线观看| 久久久久久97| 97久久人人超碰caoprom| 欧美大片在线免费观看| 日本在线观看高清完整版| 欧美大片网站在线观看| a级片免费在线观看| 久久久久久久久爱| av在线视屏| 91wwwcom在线观看| 韩国美女久久| 国产精品99久久99久久久二8| 电影网一区二区| 国产精品扒开腿做爽爽爽视频| 日本在线视频一区二区| 国产精品一区二区三区久久久| 九七电影院97理论片久久tvb| 91精品国产综合久久男男| www一区二区三区| 91在线观看网站| 久久资源综合| 日本免费高清不卡| 成人写真视频| 大桥未久一区二区| 黄色日韩在线| 黄色a级片免费| 蜜臀久久久久久久| 久久久久亚洲av片无码v| 成人av在线网| 天天躁日日躁aaaa视频| 中文字幕一区av| 久久这里只有精品国产| 欧美丝袜美女中出在线| 中文字幕有码视频| 欧美一区二区成人6969| 天堂中文在线看| 国产亚洲一区二区精品| 国产原创精品视频| 91精品国产高清久久久久久91| 欧洲精品一区二区三区| 亚洲xxxxx性| 日韩精品丝袜美腿| 日本不卡一区二区三区四区| 亚洲国产网站| 欧美一级特黄a| 豆国产96在线|亚洲| 高潮毛片无遮挡| 亚洲同性同志一二三专区| 国产欧美日韩另类| 欧美精品久久久久久久久老牛影院| 亚洲欧美另类日韩| 在线视频日韩精品| 国精一区二区三区| 日本在线精品视频| 一区二区三区四区视频免费观看| 蜜桃av噜噜一区二区三区| 午夜欧美在线| 美女福利视频在线| 国产精品资源在线| 91精品久久久久久久久久久久| 亚洲一区电影777| 97精品人妻一区二区三区在线| 亚洲国产天堂久久综合| 麻豆电影在线播放| 欧美亚洲第一区| 日韩国产在线不卡视频| 亚洲国产精品www| 国产日韩欧美三级| 国产91在线免费观看| 国产欧美一区二区在线| 久久久国产高清| 日韩免费视频线观看| 男人天堂久久久| 国产精品福利小视频| 婷婷亚洲精品| 亚洲色成人www永久在线观看| 久久99久久99| 99精品欧美一区二区| 欧美性猛交xxxx乱大交3| 丰满少妇被猛烈进入| 欧美www在线| 婷婷成人av| 亚洲欧洲国产精品久久| 久久综合婷婷| 我和岳m愉情xxxⅹ视频| 婷婷六月综合网| 国产小视频免费观看| 欧美日韩成人网| 成人永久在线| 一区二区精品在线观看| 日本va欧美va欧美va精品| 日韩人妻无码精品综合区| 欧美午夜精品在线| 色鬼7777久久| 欧亚精品中文字幕| 西野翔中文久久精品字幕| 成 年 人 黄 色 大 片大 全| 成人性生交大片免费看中文 | 91成人免费在线| 久久电影中文字幕| 国产成人综合精品| 精品福利久久久| 在线观看av日韩| 国产精品久久久久桃色tv| 亚洲无码精品在线播放| 色偷偷9999www| 粉嫩av国产一区二区三区| 黄瓜视频免费观看在线观看www| 久久99国产乱子伦精品免费| 国精产品视频一二二区| 538prom精品视频线放| 老司机99精品99| 1卡2卡3卡精品视频| 国模一区二区三区| 色婷婷免费视频| 一本大道久久精品懂色aⅴ| 国产区在线视频| 国产精品一区二区三区久久久| 911久久香蕉国产线看观看| 宇都宫紫苑在线播放| 亚洲一区二区三区爽爽爽爽爽| 黄色美女一级片| 欧美最猛性xxxxx(亚洲精品)| 色综合综合网| 五月天视频在线观看| 亚洲午夜久久久久久久久久久 | 久久精品视频在线免费观看| 精品成人无码久久久久久| 日韩亚洲精品视频| 视频二区欧美毛片免费观看| 国产一区二区视频播放| 国产女人18水真多18精品一级做 | 成人看片网页| 在线一区日本视频| 成人美女视频在线观看18| 国产午夜精品久久久久| 久久精品国产免费观看| 国产成人一二片| 在线观看免费视频高清游戏推荐| 亚洲精品午夜久久久| 欧美日韩视频精品二区| 成人精品一区二区三区电影免费 | 国产精品久久久毛片| 亚洲女厕所小便bbb| 亚洲av成人无码久久精品老人| 国产精品久久久久7777婷婷| 欧美日一区二区在线观看 | 这里只有精品在线| 日韩无码精品一区二区| 精品视频一区二区三区免费| 伊人手机在线| 日韩免费av电影| 大美女一区二区三区| 最新中文字幕免费| 国产综合在线视频| 亚洲成人日韩| 97超碰在线免费观看| 欧美第一区第二区| 久久国内精品|