成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

如何在JavaScript中正確處理變量

瀏覽:176日期:2023-10-05 18:42:02

變量無處不在。即便我們寫一個小函數或一個小工具,也要聲明、賦值和讀取變量。增強對變量的重視,可以提高代碼的可讀性和可維護性。

1.建議使用 const,要么使用 let

用 const 或 let 聲明自己的 JavaScript 變量。兩者之間的主要區別是 const 變量在聲明時需要初始化,并且一旦初始化就無法再重新賦值。

// const 需要初始化const pi = 3.14;// const 不能被重新賦值pi = 4.89; // throws 'TypeError: Assignment to constant variable'

let 聲明不需要對值初始化,可以多次重新賦值。

// let 要不要初始化隨你let result;// let 可被重新賦值result = 14;result = result * 2;

const 是一次性分配變量。因為你知道 const 變量不會被修改,所以與 let 相比,對 const 變量的推測比較容易。

聲明變量時優先使用 const,然后是 let 。

假設你正在 review 一個函數,并看到一個 const result = ... 聲明:

function myBigFunction(param1, param2) { /* 一寫代碼... */ const result = otherFunction(param1); /* 一些代碼... */ return something;}

雖然不知道 myBigFunction() 中做了些什么,但是我們可以得出結論,result 變量是只讀的。

在其他情況下,如果必須在代碼執行過程中多次重新對變量賦值,那就用 let。

2. 使變量的作用域最小化

變量位于創建它的作用域中。代碼塊和函數體為 const 和 let 變量創建作用域。

把變量保持在最小作用域中是提高可讀性的一個好習慣。

例如下面的二分查找算法的實現:

function binarySearch(array, search) { let middle; let middleItem; let left = 0; let right = array.length - 1; while(left <= right) { middle = Math.floor((left + right) / 2); middleItem = array[middle]; if (middleItem === search) { return true; } if (middleItem < search) { left = middle + 1; } else { right = middle - 1; } } return false;}binarySearch([2, 5, 7, 9], 7); // => truebinarySearch([2, 5, 7, 9], 1); // => false

變量 middle 和 middleItem 是在函數的開頭聲明的,所以這些變量在 binarySearch() 函數的整個作用域內可用。變量 middle 用來保存二叉搜索的中間索引,而變量 middleItem 保存中間的搜索項。

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

function binarySearch(array, search) { let left = 0; let right = array.length - 1; while(left <= right) { const middle = Math.floor((left + right) / 2); const middleItem = array[middle]; if (middleItem === search) { return true; } if (middleItem < search) { left = middle + 1; } else { right = middle - 1; } } return false;}

現在 middle 和 middleItem 只存在于使用變量的作用域內。他們的生命周期極短,所以更容易推斷它們的用途。

3. 易于使用

我總是習慣于在函數開始的時候去聲明所有變量,尤其是在寫一些比較大的函數時。但是這樣做會使我在函數中使用變量的意圖變得非常混亂。

所以應該在變量聲明時應該盡可能靠的近使用位置。這樣你就不必去猜:哦,這里聲明了變量,但是…它被用在什么地方呢?

假設有一個函數,在函數有包含很多語句。你可以在函數的開頭聲明并初始化變量 result,但是只在 return 語句中使用了 result:

function myBigFunction(param1, param2) { const result = otherFunction(param1); let something; /* * 一些代碼... */ return something + result;}

問題在于 result 變量在開頭聲明,卻只在結尾用到。我們并沒有充分的理由在開始的時后就聲明這個變量。

所以為了更好地理解 result 變量的功能和作用,要始終使變量聲明盡可能的靠近使用它位置。

如果把代碼改成這樣:

function myBigFunction(param1, param2) { let something; /* * 一些代碼... */ const result = otherFunction(param1); return something + result;}

現在是不是就清晰多了。

4. 合理的命名

你可能已經知道了很多關于變量命名的知識,所以在這里不會展開說明。不過在眾多的命名規則中,我總結出了兩個重要的原則:

第一個很簡單:使用駝峰命名法,并終如一地保持這種風格。

const message = ’Hello’;const isLoading = true;let count;

這個規則的一個例外是一些特定的值:比如數字或具有特殊含義的字符串。包特定值的變量通常用大寫加下劃線的形式,與常規變量區分開:

const SECONDS_IN_MINUTE = 60;const GRAPHQL_URI = ’http://site.com/graphql’;

我認為第二條是:變量名稱應該清楚無誤地表明是用來保存哪些數據的。

下面是一些很好的例子:

let message = ’Hello’;let isLoading = true;let count;

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

isLoading 也一樣,是一個布爾值,用來指示是否正在進行加載。

毫無疑問,count 變量表示一個數字類型的變量,其中包含一些計數結果。

一定要選一個能夠清楚表明其作用的變量名。

看一個例子,假設你看到了下面這樣的代碼:

function salary(ws, r) { let t = 0; for (w of ws) { t += w * r; } return t;}

你能很容易知道函數的作用嗎?與薪水的計算有關?非常不幸,我們很難看出 ws、 r、 t、 w這些變量名的作用。

但是如果代碼是這樣:

function calculateTotalSalary(weeksHours, ratePerHour) { let totalSalary = 0; for (const weekHours of weeksHours) { const weeklySalary = weekHours * ratePerHour; totalSalary += weeklySalary; } return totalSalary;}

我們就很容易知道它們的作用,這就是合理命名的力量。

5.采用中間變量

我一般盡可能避免寫注釋,更喜歡寫出能夠自我描述的代碼,通過對變量、屬性、函數、類等進行合理的命名來表達代碼的意圖。

如果想使代碼本身稱為文檔,一個好習慣是引入中間變量,這在在處理長表達式時很好用。

比如下面的表達式:

const sum = val1 * val2 + val3 / val4;

可以通過引入兩個中間變量來提高長表達式的可讀性:

const multiplication = val1 * val2;const division = val3 / val4;const sum = multiplication + division;

再回顧一下前面的二叉搜索算法實現:

function binarySearch(array, search) { let left = 0; let right = array.length - 1; while(left <= right) { const middle = Math.floor((left + right) / 2); const middleItem = array[middle]; if (middleItem === search) { return true; } if (middleItem < search) { left = middle + 1; } else { right = middle - 1; } } return false;}

里面的 middleItem 就是一個中間變量,用于保存中間項。使用中間變量 middleItem 比直接用 array[middle] 更容易。

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

function binarySearch(array, search) { let left = 0; let right = array.length - 1; while(left <= right) { const middle = Math.floor((left + right) / 2); if (array[middle] === search) { return true; } if (array[middle] < search) { left = middle + 1; } else { right = middle - 1; } } return false;}

沒有中間變量的解釋,這個版本稍微不太好理解。

通過使用中間變量用代碼解釋代碼。中間變量可能會增加一些語句,但出于增強代碼可讀性的目的還是非常值得的的。

總結 變量無處不在。在 JavaScript 中使用變量時,首選 const,其次是 let。 盡可能縮小變量的作用域。同樣,聲明變量時要盡可能靠近其使用位置。 合理的命名是非常重要的。要遵循以下規則:變量名稱應該清楚無誤地表明是用來保存哪些數據的。不要害怕使用更長的變量名:要追求清晰而不是簡短。 最后,最好用代碼自己來解釋代碼。在高度復雜的地方,我更喜歡引入中間變量。

以上就是如何在JavaScript中正確處理變量的詳細內容,更多關于JavaScript 處理變量的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
欧美日韩和欧美的一区二区| 久久综合狠狠综合久久综合88| 欧美一区二区三区性视频| 日韩精品成人一区二区在线| 欧美日韩喷水| 久久久久久久久久美女| 99精品视频在线观看| 精品少妇一区二区三区在线视频| 国产精品伊人色| 欧美日韩国产在线观看| 国内成人自拍视频| 欧美一区二区三区四区五区 | 国产农村妇女精品一二区| 国产精品黄色在线观看| 欧美少妇一区| 国产精品久久久久久久久免费丝袜 | 国产欧美精品一区| 欧美日韩大片一区二区三区| 亚洲国产精品成人综合色在线婷婷| 91美女片黄在线观看91美女| 国产欧美日韩亚州综合| 欧美日韩精品免费观看视频完整| 久久久久99精品国产片| 欧美高清视频一区| 亚洲国产精品高清| 怡红院精品视频在线观看极品| 国产精品女人毛片| 久久久久99精品国产片| 美脚の诱脚舐め脚责91| 一区二区三区欧美视频| 亚洲综合久久久久| 久久久久久久久久久久久久久99 | 欧美丝袜丝交足nylons| 久久国产精品免费| 在线观看欧美精品| 国产一区二区三区av电影| 日韩精品一区二| 日韩高清中文字幕一区| 欧美日韩精品一区视频| 丰满亚洲少妇av| 久久亚洲二区三区| 国产精品va| 亚洲成人动漫在线免费观看| 91黄视频在线观看| 国产成人欧美日韩在线电影| 久久久www成人免费毛片麻豆| 在线观看亚洲| 免费看欧美女人艹b| 日韩欧美国产小视频| 亚洲欧美综合| 一区二区三区四区视频精品免费| 免费亚洲一区二区| 激情小说欧美图片| 久久久亚洲精华液精华液精华液| 伊人激情综合| 青青草成人在线观看| 日韩欧美另类在线| 亚洲午夜黄色| 日韩综合在线视频| 精品国产制服丝袜高跟| 亚洲另类视频| 精油按摩中文字幕久久| 久久先锋影音av| 一区二区动漫| 日韩电影免费在线| 日韩一级免费一区| 欧美激情性爽国产精品17p| 一区二区三区国产精品| 欧美久久婷婷综合色| 欧美精品一区二区视频| 日韩va欧美va亚洲va久久| 久久网站热最新地址| 香蕉久久a毛片| 成人性生交大片免费看视频在线 | 丁香六月综合激情| 国产精品第13页| 在线观看91精品国产入口| 午夜精品区一区二区三| 婷婷一区二区三区| 欧美精品一区二区三区在线播放| 伊人影院久久| 精品一区二区三区在线视频| 国产精品国产三级国产普通话三级 | 最新亚洲一区| 精品在线观看视频| 最近中文字幕一区二区三区| 欧洲视频一区二区| 欧美精品1区| 日本va欧美va精品| 中文字幕巨乱亚洲| 欧美日韩极品在线观看一区| 精品99视频| 精品无人码麻豆乱码1区2区| 最新不卡av在线| 91麻豆精品国产自产在线 | 三级不卡在线观看| 国产亚洲精品7777| 欧美日韩五月天| 亚洲激情网址| 成人免费看片app下载| 午夜精品福利一区二区三区av| 久久精品水蜜桃av综合天堂| 在线看国产日韩| 亚洲精品视频啊美女在线直播| 国产精品123区| 一区二区三区在线播放| 精品粉嫩aⅴ一区二区三区四区| 色美美综合视频| 激情综合网址| 成人精品一区二区三区四区| 日日夜夜精品视频免费| 国产精品久久久久aaaa樱花| 91精品国产免费| 国产日韩欧美一区二区三区在线观看 | 亚洲一区在线视频观看| 久久久美女毛片| 欧美午夜理伦三级在线观看| 国产欧美不卡| 欧美日韩精品免费看| 国产高清精品网站| 日本美女一区二区| 亚洲女爱视频在线| 久久久不卡影院| 欧美一区二区私人影院日本| 色妞www精品视频| 99亚洲一区二区| 欧美日韩一区二区视频在线| 国产91对白在线观看九色| 日产欧产美韩系列久久99| 亚洲美女淫视频| 久久―日本道色综合久久| 欧美三级一区二区| 国产精品入口66mio| 欧美日韩精品免费看| 国产美女一区二区三区| 婷婷夜色潮精品综合在线| 亚洲色图欧洲色图婷婷| 久久久久国色av免费看影院| 欧美一区二区视频在线观看2022 | 欧美日韩精品三区| 色av成人天堂桃色av| 在线观看一区| 欧美激情一区| 99久久国产综合精品麻豆| 国产福利视频一区二区三区| 老司机午夜精品| 日本美女一区二区| 香蕉乱码成人久久天堂爱免费| 亚洲欧美日韩精品久久久久| 国产精品动漫网站| 国产精品视频一二| 精品三级在线看| 欧美一区二区福利在线| 欧美少妇性性性| 欧美综合色免费| 在线视频一区二区三| 一本色道久久综合精品竹菊| 亚洲综合三区| 亚洲欧美成人| 六月婷婷一区| 色网综合在线观看| 色94色欧美sute亚洲线路一ni | 久久久一区二区三区捆绑**| 欧美电视剧在线观看完整版| 欧美二区三区的天堂| 在线播放国产精品二区一二区四区| 欧美亚男人的天堂| 欧美色图12p| 欧美另类一区二区三区| 欧美肥胖老妇做爰| 日韩一区二区在线观看视频播放| 欧美日韩国产综合久久| 欧美人牲a欧美精品| 91精品蜜臀在线一区尤物| 91精品国产91久久综合桃花| 日韩亚洲欧美综合| 日韩午夜精品电影| 欧美v日韩v国产v| 精品对白一区国产伦| 国产偷国产偷精品高清尤物| 国产精品色眯眯| 成人免费在线播放视频| 亚洲精品乱码久久久久久 | 国产精品成人一区二区艾草| 国产精品久久久久久户外露出| 亚洲欧洲另类国产综合| 亚洲视频一二区| 亚洲视频综合在线| 亚洲欧美国产三级| 亚洲精品第一国产综合野| 亚洲成人动漫一区| 美腿丝袜一区二区三区| 国产综合成人久久大片91| 国产精品影视在线观看| 不卡的av网站| 欧美视频一区| 国产精品免费一区二区三区在线观看| 欧美中文字幕| 欧美亚日韩国产aⅴ精品中极品| 欧美一区二区三区四区久久|