电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

如何在JavaScript中正確處理變量

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

變量無處不在。即便我們寫一個(gè)小函數(shù)或一個(gè)小工具,也要聲明、賦值和讀取變量。增強(qiáng)對(duì)變量的重視,可以提高代碼的可讀性和可維護(hù)性。

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

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

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

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

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

const 是一次性分配變量。因?yàn)槟阒?const 變量不會(huì)被修改,所以與 let 相比,對(duì) const 變量的推測(cè)比較容易。

聲明變量時(shí)優(yōu)先使用 const,然后是 let 。

假設(shè)你正在 review 一個(gè)函數(shù),并看到一個(gè) const result = ... 聲明:

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

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

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

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

變量位于創(chuàng)建它的作用域中。代碼塊和函數(shù)體為 const 和 let 變量創(chuàng)建作用域。

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

例如下面的二分查找算法的實(shí)現(xiàn):

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 是在函數(shù)的開頭聲明的,所以這些變量在 binarySearch() 函數(shù)的整個(gè)作用域內(nèi)可用。變量 middle 用來保存二叉搜索的中間索引,而變量 middleItem 保存中間的搜索項(xiàng)。

但是 middle 和 middleItem 變量只用在 while 循環(huán)中。那為什么不直接在 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;}

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

3. 易于使用

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

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

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

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

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

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

如果把代碼改成這樣:

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

現(xiàn)在是不是就清晰多了。

4. 合理的命名

你可能已經(jīng)知道了很多關(guān)于變量命名的知識(shí),所以在這里不會(huì)展開說明。不過在眾多的命名規(guī)則中,我總結(jié)出了兩個(gè)重要的原則:

第一個(gè)很簡(jiǎn)單:使用駝峰命名法,并終如一地保持這種風(fēng)格。

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

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

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

我認(rèn)為第二條是:變量名稱應(yīng)該清楚無誤地表明是用來保存哪些數(shù)據(jù)的。

下面是一些很好的例子:

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

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

isLoading 也一樣,是一個(gè)布爾值,用來指示是否正在進(jìn)行加載。

毫無疑問,count 變量表示一個(gè)數(shù)字類型的變量,其中包含一些計(jì)數(shù)結(jié)果。

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

看一個(gè)例子,假設(shè)你看到了下面這樣的代碼:

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

你能很容易知道函數(shù)的作用嗎?與薪水的計(jì)算有關(guān)?非常不幸,我們很難看出 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.采用中間變量

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

如果想使代碼本身稱為文檔,一個(gè)好習(xí)慣是引入中間變量,這在在處理長(zhǎng)表達(dá)式時(shí)很好用。

比如下面的表達(dá)式:

const sum = val1 * val2 + val3 / val4;

可以通過引入兩個(gè)中間變量來提高長(zhǎng)表達(dá)式的可讀性:

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

再回顧一下前面的二叉搜索算法實(shí)現(xiàn):

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 就是一個(gè)中間變量,用于保存中間項(xiàng)。使用中間變量 middleItem 比直接用 array[middle] 更容易。

與缺少 middleItem 變量的函數(shù)版本進(jìn)行比較:

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;}

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

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

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

以上就是如何在JavaScript中正確處理變量的詳細(xì)內(nèi)容,更多關(guān)于JavaScript 處理變量的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 蓄电池回收,ups电池后备电源回收,铅酸蓄电池回收,机房电源回收-广州益夫铅酸电池回收公司 | 南京租车,南京汽车租赁,南京包车,南京会议租车-南京七熹租车 | 净化工程_无尘车间_无尘车间装修-广州科凌净化工程有限公司 | 中国品牌门窗网_中国十大门窗品牌_著名门窗品牌 | 量子管通环-自清洗过滤器-全自动反冲洗过滤器-沼河浸过滤器 | 吸音板,隔音板,吸音材料,吸音板价格,声学材料 - 佛山诺声吸音板厂家 | 无硅导热垫片-碳纤维导热垫片-导热相变材料厂家-东莞市盛元新材料科技有限公司 | led太阳能路灯厂家价格_风光互补庭院灯_农村市政工程路灯-中山华可路灯品牌 | 冷库安装厂家_杭州冷库_保鲜库建设-浙江克冷制冷设备有限公司 | 碳钢法兰厂家,非标法兰,定制异型,法兰生产厂家-河北九瑞管道 | 彭世修脚_修脚加盟_彭世修脚加盟_彭世足疗加盟_足疗加盟连锁_彭世修脚技术培训_彭世足疗 | 锤式粉碎机,医药粉碎机,锥式粉碎机-无锡市迪麦森机械制造有限公司 | 青海电动密集架_智能密集架_密集架价格-盛隆柜业青海档案密集架厂家 | 工业用品一站式采购平台|南创工品汇-官网|广州南创 | 私人别墅家庭影院系统_家庭影院音响_家庭影院装修设计公司-邦牛影音 | 法兰螺母 - 不锈钢螺母制造厂家 - 万千紧固件--螺母街 | 氟氨基酮、氯硝柳胺、2-氟苯甲酸、异香兰素-新晨化工 | 隐形纱窗|防护纱窗|金刚网防盗纱窗|韦柏纱窗|上海青木装潢制品有限公司|纱窗国标起草单位 | 加盟店-品牌招商加盟-创业项目商机平台 | 企业微信scrm管理系统_客户关系管理平台_私域流量运营工具_CRM、ERP、OA软件-腾辉网络 | 齿轮减速电机一体机_蜗轮蜗杆减速马达-德国BOSERL齿轮减速机带电机生产厂家 | 丹尼克尔拧紧枪_自动送钉机_智能电批_柔性振动盘_螺丝供料器品牌 | 合肥抖音SEO网站优化-网站建设-网络推广营销公司-百度爱采购-安徽企匠科技 | 飞扬动力官网-广告公司管理软件,广告公司管理系统,喷绘写真条幅制作管理软件,广告公司ERP系统 | 日本SMC气缸接头-速度控制阀-日本三菱伺服电机-苏州禾力自动化科技有限公司 | 东莞螺杆空压机_永磁变频空压机_节能空压机_空压机工厂批发_深圳螺杆空压机_广州螺杆空压机_东莞空压机_空压机批发_东莞空压机工厂批发_东莞市文颖设备科技有限公司 | 可程式恒温恒湿试验箱|恒温恒湿箱|恒温恒湿试验箱|恒温恒湿老化试验箱|高低温试验箱价格报价-广东德瑞检测设备有限公司 | 单机除尘器 骨架-脉冲除尘器设备生产厂家-润天环保设备 | 沈阳网站建设_沈阳网站制作_沈阳网页设计-做网站就找示剑新零售 沈阳缠绕膜价格_沈阳拉伸膜厂家_沈阳缠绕膜厂家直销 | 减速机三参数组合探头|TSM803|壁挂式氧化锆分析仪探头-安徽鹏宸电气有限公司 | 专业深孔加工_东莞深孔钻加工_东莞深孔钻_东莞深孔加工_模具深孔钻加工厂-东莞市超耀实业有限公司 | 高压直流电源_特种变压器_变压器铁芯-希恩变压器定制厂家 | 啤酒设备-小型啤酒设备-啤酒厂设备-济南中酿机械设备有限公司 | 泰州物流公司_泰州货运公司_泰州物流专线-东鑫物流公司 | 喷砂机厂家_自动除锈抛丸机价格-成都泰盛吉自动化喷砂设备 | 软文发布平台 - 云软媒网络软文直编发布营销推广平台 | 广东燎了网络科技有限公司官网-网站建设-珠海网络推广-高端营销型外贸网站建设-珠海专业h5建站公司「了了网」 | 槽钢冲孔机,槽钢三面冲,带钢冲孔机-山东兴田阳光智能装备股份有限公司 | 成都LED显示屏丨室内户外全彩led屏厂家方案报价_四川诺显科技 | 警方提醒:赣州约炮论坛真的安全吗?2025年新手必看的网络交友防坑指南 | 超细粉碎机|超微气流磨|气流分级机|粉体改性设备|超微粉碎设备-山东埃尔派粉碎机厂家 |