JS中可以改善代碼的5種重構(gòu)技術(shù)分享
編寫代碼很有趣,我們非常喜歡它。直到一個錯誤突然出現(xiàn),需要相當長的時間來解決它。有時,錯誤并不明顯,因為代碼按預(yù)期運行,但在生產(chǎn)中可能會導(dǎo)致錯誤??赡軙行阅芎涂稍L問性方面的錯誤,這會導(dǎo)致用戶體驗不佳。通過重構(gòu)代碼可以減少這類錯誤。
代碼重構(gòu)涉及在不改變其外部功能的情況下對現(xiàn)有代碼進行改進。這是編程的核心部分之一,不能忽視,否則,我們將無法實現(xiàn)代碼的更好版本。代碼重構(gòu)可以提高代碼的可讀性、可維護性和可擴展性。它還旨在提高性能和提高開發(fā)人員的生產(chǎn)力。
今天,我們將研究一些技巧,這些技巧可以幫助我們以更好的方式重構(gòu)代碼。
如何整合重構(gòu)
在尋找改進重構(gòu)的技巧之前,讓我們看看如何將代碼重構(gòu)集成到你的編碼過程中??梢允褂靡韵陆ㄗh來實現(xiàn)這個目的:
- 專門分配時間來重構(gòu)代碼
- 將較大的重構(gòu)問題分解為較小的問題以進行管理
- 嘗試讓整個團隊參與重構(gòu)過程
- 使用自動化工具,可以幫助您查找常見的重構(gòu)錯誤
提取方法
這種方法涉及將代碼塊轉(zhuǎn)換為單獨的方法/函數(shù)。這樣做是為了提高代碼的結(jié)構(gòu)和可讀性。通過提取較長且復(fù)雜的代碼塊,將其變成更小且易于管理的方法來實現(xiàn)這一目標。
要使用這種技術(shù),我們首先需要找到一個執(zhí)行特定任務(wù)的代碼塊,這些任務(wù)有點復(fù)雜。在識別之后,我們提取代碼并將其放入一個新方法中。此外,確保為該方法起一個有意義的名稱?,F(xiàn)在,在我們需要代碼的地方調(diào)用它們。
重構(gòu)前
function calculateInvoiceTotal(items) {
let total = 0;
for (let i = 0; i < items.length; i++) {
const item = items[i];
if (!item.quantity || !item.price) {
console.error('Invalid item', item);
continue;
}
const itemTotal = item.quantity * item.price;
total += itemTotal;
}
return total;
}重構(gòu)后
function calculateInvoiceTotal(items) {
let total = 0;
for (let i = 0; i < items.length; i++) {
const item = items[i];
const itemTotal = calculateItemTotal(item);
total += itemTotal;
}
return total;
}
function calculateItemTotal(item) {
if (!item.quantity || !item.price) {
console.error('Invalid item', item);
return 0;
}
return item.quantity * item.price;
}可以看到我們?nèi)绾螌⒃?for 循環(huán)內(nèi)運行的復(fù)雜代碼轉(zhuǎn)換為另一種方法以簡化和提高可讀性。
用符號常量替換魔術(shù)數(shù)字
這個代碼重構(gòu)是為了編寫更清晰、更易讀的代碼。魔術(shù)數(shù)字只是指硬編碼的數(shù)值。編寫硬編碼的數(shù)字會給其他人帶來困惑,因為它們的目的沒有定義。將硬編碼的值轉(zhuǎn)換為具有有意義名稱的變量肯定有助于其他人理解它。此外,還可以為其添加注釋以進一步解釋。這也有助于調(diào)試和降低將來出現(xiàn)錯誤的風險。
重構(gòu)前
if (temperature > 32) {
// Do something if temperature is above freezing
}重構(gòu)后
const int FREEZING_POINT = 32;
if (temperature > FREEZING_POINT) {
// Do something if temperature is above freezing
}合并重復(fù)代碼
復(fù)制或相同的代碼可能會出現(xiàn)在來自不同位置的代碼中。這個代碼不需要完全相同,但它可以執(zhí)行類似的任務(wù)或從原始代碼稍微擴展一點。重復(fù)的代碼可能導(dǎo)致多種問題,包括增加維護成本、難以對代碼庫進行更改以及引入錯誤的風險更高。
在重構(gòu)代碼時,必須注意查找重復(fù)的代碼。在找到這樣的代碼時,處理這個問題的一種方法是將這些代碼轉(zhuǎn)換為單個可重用的函數(shù)/方法。
重構(gòu)前
function calculateTotal(numbers) {
let total = 0;
for (let i = 0; i < numbers.length; i++) {
total += numbers[i];
}
return total;
}
function calculateAverage(numbers) {
let total = 0;
for (let i = 0; i < numbers.length; i++) {
total += numbers[i];
}
const average = total / numbers.length;
return average;
}重構(gòu)后
function calculateSum(numbers) {
let total = 0;
for (let i = 0; i < numbers.length; i++) {
total += numbers[i];
}
return total;
}
function calculateTotal(numbers) {
return calculateSum(numbers);
}
function calculateAverage(numbers) {
const total = calculateSum(numbers);
const average = total / numbers.length;
return average;
}在之前的代碼示例中,我們在求和并再次求和以找到平均值。在之后,我們用提供給它們兩者之和的函數(shù)替換了這個過程。
簡化方法
當你尋找要優(yōu)化的方法/功能時,它與識別非常相似??梢詾檫壿嬜龊喕姆椒ɑ蚴蛊淇勺x和清潔。此技術(shù)可以幫助你減少代碼行。
此方法可以分解為較小的代碼塊,可以在函數(shù)中找到它們以進行優(yōu)化。以下是這些代碼塊:
- 刪除不必要的變量和表達式:可能有一些用于調(diào)試的變量或表達式被遺漏,例如JavaScript中的console.log。
- 使用內(nèi)置功能:有時使用庫或語言的內(nèi)置功能會更好。因為可以用更少的代碼實現(xiàn)相同的功能。
- 簡化條件語句:如果一個方法有復(fù)雜的條件語句,請考慮通過合并條件或使用三元運算符來簡化它們。
使用懶加載
這是一種只在需要時加載對象的技術(shù)。這可以通過減少內(nèi)存使用量來提高應(yīng)用程序的性能。這將加快應(yīng)用程序的加載速度。
這種技術(shù)在Web開發(fā)中非常流行。尤其是在像React這樣的JavaScript框架中,可以通過懶加載導(dǎo)入不同的組件。這也可以根據(jù)需要加載圖像。
重構(gòu)前
import React from 'react';
import MyComponent from './MyComponent';
const App = () => {
return (
<div>
<h1>My App</h1>
<MyComponent />
</div>
);
}
export default App;重構(gòu)后
import React, { lazy, Suspense } from 'react';
const MyComponent = lazy(() => import('./MyComponent'));
const App = () => {
return (
<div>
<h1>My App</h1>
<Suspense fallback={<div>Loading...</div>}>
<MyComponent />
</Suspense>
</div>
);
}
export default App;在更新版本中,我們使用 lazy 功能異步導(dǎo)入 MyComponent 組件。這意味著該組件僅在實際需要時才加載,從而提高了我們應(yīng)用程序的整體性能。我們還使用 Suspense 組件在加載組件時顯示回退 UI。
總結(jié)
重構(gòu)是任何希望提高代碼質(zhì)量、性能和可維護性的開發(fā)者的基本實踐。通過花時間分析和優(yōu)化代碼,可以消除冗余,降低復(fù)雜性,并創(chuàng)建更高效且可擴展的應(yīng)用程序。
通過不斷審查和改進你的代碼,你可以創(chuàng)建一個更強大、更具彈性的應(yīng)用程序。希望這篇文章能幫助您了解一些重構(gòu)技巧。
到此這篇關(guān)于JS中可以改善代碼的5種重構(gòu)技術(shù)分享的文章就介紹到這了,更多相關(guān)JS重構(gòu)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
javasciprt下jquery函數(shù)$.post執(zhí)行無響應(yīng)的解決方法
這篇文章主要介紹了javasciprt下jquery函數(shù)$.post執(zhí)行無響應(yīng)的解決方法,需要的朋友可以參考下2014-03-03
JavaScript和ActionScript的交互實現(xiàn)代碼
JavaScript和ActionScript的交互實現(xiàn)代碼,需要js與flash交互的朋友可以學習下。2010-08-08
利用JavaScript實現(xiàn)簡單全選和全不選的思路和方法
最近開始練習js的基本操作,常常因為一些小疏忽導(dǎo)致頁面效果無法實現(xiàn),下面這篇文章主要給大家介紹了關(guān)于利用JavaScript實現(xiàn)簡單全選和不全選的思路和方法,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-07-07
Javascript實現(xiàn)div的toggle效果實例分析
這篇文章主要介紹了Javascript實現(xiàn)div的toggle效果的方法,實例分析了采用純javascript實現(xiàn)toggle效果的相關(guān)技巧,需要的朋友可以參考下2015-06-06

