前言
好的代碼一定是整潔的僚匆,并且能夠幫助閱讀的人快速理解和定位微渠。好的代碼可以加快應(yīng)用的開發(fā)迭代速度,不必花過多的時(shí)間來修復(fù) bug 和完善代碼咧擂。
好的代碼不但能夠使得新的項(xiàng)目成員更容易加入項(xiàng)目逞盆,同時(shí)方便項(xiàng)目組成員快速做好 Back up。好的代碼便于促進(jìn)團(tuán)隊(duì)間交流合作提升開發(fā)效率松申。
代碼質(zhì)量評價(jià)標(biāo)準(zhǔn)
有編碼經(jīng)驗(yàn)的人對代碼都有一定的“鑒賞力”云芦,能夠憑感覺給出代碼好壞的主觀評價(jià)。但是這種憑感覺的方式太過個(gè)性隨意攻臀,所謂仁者見仁智者見智焕数,很難達(dá)成共識(shí),那有沒有一種公認(rèn)的標(biāo)準(zhǔn)來鑒定代碼質(zhì)量呢刨啸?
答案是有的堡赔。這里簡單分享當(dāng)下較常用的評價(jià)標(biāo)準(zhǔn),其中包括:編碼規(guī)范设联、可讀性善已、可維護(hù)性、重復(fù)度及可測試性离例。
編碼規(guī)范主要包含是否遵守了最佳實(shí)踐和團(tuán)隊(duì)編碼規(guī)范换团,是否包含可能出問題的代碼,以及可能存在安全的漏洞宫蛆。編碼規(guī)范有助于提高團(tuán)隊(duì)內(nèi)協(xié)助的效率以及代碼的可維護(hù)性艘包。
可讀性Code Review 是一個(gè)很好的測驗(yàn)代碼可讀性的手段的猛。如果你的同事可以輕松地讀懂你寫的代碼,那說明你的代碼可讀性很好想虎;反之則說明你的代碼可讀性有待提高了卦尊。遵守編碼規(guī)范也能讓我們寫出可讀性更好的代碼。
可維護(hù)性代碼的可維護(hù)性是由很多因素協(xié)同作用的結(jié)果舌厨。代碼的可讀性好岂却、簡潔、可擴(kuò)展性好裙椭,就會(huì)使得代碼易維護(hù)躏哩;更細(xì)化地講,如果代碼分層清晰揉燃、模塊化好扫尺、高內(nèi)聚低耦合、遵從基于接口而非實(shí)現(xiàn)編程的設(shè)計(jì)原則等等你雌,那就可能意味著代碼易維護(hù)器联。除此之外,代碼的易維護(hù)性還跟項(xiàng)目代碼量的多少婿崭、業(yè)務(wù)的復(fù)雜程度拨拓、利用到的技術(shù)的復(fù)雜程度、文檔是否全面等諸多因素有關(guān)氓栈。
重復(fù)度遵守 Don’t Repeat Yourself 原則渣磷,盡量減少重復(fù)代碼的編寫,復(fù)用已有的代碼授瘦。對項(xiàng)目定期進(jìn)行代碼重復(fù)度檢測是一個(gè)很有意義的事醋界,可以幫助開發(fā)人員發(fā)現(xiàn)冗余代碼,進(jìn)行代碼抽象和重構(gòu)提完。重復(fù)的代碼一旦出錯(cuò)形纺,意味著加倍的工作量和持續(xù)的不可控。如果代碼中有大量的重復(fù)代碼徒欣,就要考慮將重復(fù)的代碼提取出來逐样,封裝成公共的方法或者組件。
可測試性代碼可測試性的好壞打肝,同樣可以反應(yīng)代碼質(zhì)量的好壞脂新。代碼的可測試性差,比較難寫單元測試粗梭,那基本上就能說明代碼設(shè)計(jì)得有問題争便。
除此之外還有很多代碼質(zhì)量評價(jià)標(biāo)準(zhǔn)。我們需要一些取舍断医,選取部分大家有共識(shí)的規(guī)則定義團(tuán)隊(duì)好的代碼標(biāo)準(zhǔn)滞乙。
代碼質(zhì)量維度
當(dāng)前版本通過 @iceworks/doctor 從 5 個(gè)維度對代碼進(jìn)行評分:
[圖片上傳失敗...(image-8f14a9-1649513420524)]
- 最佳實(shí)踐: 通過 @iceworks/eslint-plugin-best-practices 分析項(xiàng)目奏纪,提出符合當(dāng)前工程特征(對 ice 和 Rax項(xiàng)目友好)的最佳實(shí)踐及阻塞問題發(fā)布卡口,幫助開發(fā)者優(yōu)化項(xiàng)目性能酷宵,避免潛在 bug 亥贸。
- 安全實(shí)踐: 通過 @iceworks/eslint-plugin-security-practices 掃碼代碼檢測工程中可能存在的安全風(fēng)險(xiǎn),包含 url 浇垦、敏感成詞、明文賬密信息及 npm 包證書檢測荣挨,降低項(xiàng)目安全風(fēng)險(xiǎn)男韧,守衛(wèi)項(xiàng)目安全。
- 阿里代碼規(guī)范: 這一維度主要反饋開發(fā)人員對于 eslint-config-ali 阿里開發(fā)規(guī)約的遵守程度默垄。
- 可維護(hù)度: 通過 typhonjs-escomplex 對文件進(jìn)行掃碼此虑,得出每個(gè)文件的可維護(hù)度,可讀性及復(fù)雜度評分口锭。針對得分較差的文件可以進(jìn)行深度分析幫助開發(fā)者更好的重構(gòu)復(fù)雜代碼朦前。
- 重復(fù)度: 通過 jscpd 計(jì)算重復(fù)出現(xiàn)的代碼區(qū)塊占比,計(jì)算出 clone 分?jǐn)?shù)鹃操。并逐一列舉重復(fù)的代碼韭寸,方便開發(fā)者快速定位重復(fù)代碼,將其封裝成公共的方法或者組件卿闹。
根據(jù)上述 5 個(gè)維度通過加權(quán)平均的方式計(jì)算項(xiàng)目質(zhì)量分桑逝,并根據(jù)木桶效應(yīng)喊积,在計(jì)算得分的過程中加大了最低分的權(quán)重,得出最終項(xiàng)目質(zhì)量評分晶渠。