ホームページ > ウェブフロントエンド > jsチュートリアル > JavaScript のベスト プラクティス: クリーンで効率的で保守可能なコードを作成する

JavaScript のベスト プラクティス: クリーンで効率的で保守可能なコードを作成する

DDD
リリース: 2024-11-27 09:22:10
オリジナル
724 人が閲覧しました

Best Practices in JavaScript: Writing Clean, Efficient, and Maintainable Code

1.オプションのチェーン (?.) でコードを保護します

深くネストされたプロパティにアクセスすると、プロパティが存在しない場合、TypeError が発生することがよくあります。オプションのチェーン (?.) は、冗長なチェックを書かずにこれらのプロパティに安全にアクセスするクリーンな方法を提供します。

例:

const user = { profile: { name: 'Alice' } };  

console.log(user.profile?.name); // Alice  
console.log(user.profile?.age); // undefined (No error)  
ログイン後にコピー

なぜ使用するのですか?

オプションのチェーンは、未定義または null 値によるクラッシュを防ぎ、if ステートメントの繰り返しを排除することでコードをクリーンに保ちます。


2.動的インポートによるパフォーマンスの最適化

動的インポートを使用すると、必要な場合にのみ JavaScript モジュールをロードできるため、初期バンドル サイズが削減され、アプリケーションのパフォーマンスが向上します。

例:

async function loadChart() {  
  const { Chart } = await import('chart.js');  
  const myChart = new Chart(canvas, { type: 'bar', data: {...} });  
}  
ログイン後にコピー

なぜ使用するのですか?

動的インポートにより、コード分割が可能になり、特定の機能に必要な JavaScript のみが確実に読み込まれるようになり、読み込み時間が短縮され、ユーザー エクスペリエンスが向上します。


3.分割とデフォルトを使用してコードを簡素化する

デフォルト値を使用して構造を分割すると、未定義を避けるためのフォールバック値を提供しながら、オブジェクトまたは配列からプロパティを簡潔に抽出できます。

例:

const settings = { theme: 'dark' };  

const { theme = 'light', language = 'en' } = settings;  

console.log(theme); // dark  
console.log(language); // en (default)  
ログイン後にコピー

なぜ使用するのですか?

このアプローチにより、ボイラープレート コードが削減され、予期しない未定義値が回避されるため、ロジックがより堅牢で読みやすくなります。


4.デバウンスとスロットルでパフォーマンスを向上

スクロールやサイズ変更などのイベントの処理が頻繁すぎると、負荷が高くなる可能性があります。 デバウンシングを使用して実行を遅らせるか、スロットリングを使用して関数呼び出しの頻度を制限します。

デバウンスの例:

function debounce(func, delay) {  
  let timeout;  
  return (...args) => {  
    clearTimeout(timeout);  
    timeout = setTimeout(() => func(...args), delay);  
  };  
}  

window.addEventListener('resize', debounce(() => console.log('Resized!'), 300));  
ログイン後にコピー

スロットルの例:

function throttle(func, limit) {  
  let lastCall = 0;  
  return (...args) => {  
    const now = Date.now();  
    if (now - lastCall >= limit) {  
      lastCall = now;  
      func(...args);  
    }  
  };  
}  

window.addEventListener('scroll', throttle(() => console.log('Scrolled!'), 200));  
ログイン後にコピー

なぜ使用するのですか?

どちらの手法も、イベント ハンドラーがトリガーされる回数を減らすことでブラウザのパフォーマンスを最適化し、アプリケーションをよりスムーズで応答性の高いものにします。


5.メモ化による高価な計算のキャッシュ

メモ化を使用して関数呼び出しの結果をキャッシュすることで、冗長な計算を回避します。

例:

function memoize(fn) {  
  const cache = new Map();  
  return (...args) => {  
    const key = JSON.stringify(args);  
    if (cache.has(key)) return cache.get(key);  
    const result = fn(...args);  
    cache.set(key, result);  
    return result;  
  };
}  

const factorial = memoize(n => (n <= 1 ? 1 : n * factorial(n - 1)));  

console.log(factorial(5)); // 120  
console.log(factorial(5)); // Retrieved from cache  
ログイン後にコピー

なぜ使用するのですか?

メモ化は、以前に計算された結果を再利用することで計算負荷を軽減し、再帰関数や複雑な計算のパフォーマンスを大幅に向上させます。


結論

これらの独自の JavaScript ベスト プラクティスをワークフローに組み込むことで、よりクリーンで高速、効率的なコードを作成できます。より安全なプロパティ アクセスのためにオプションのチェーンを使用する場合でも、パフォーマンスのために動的インポートを活用する場合でも、これらのテクニックは、最新の開発者としてのあなたを際立たせます。

次の実践のうちどれを最初に試しますか?コメントでご意見を共有してください!

以上がJavaScript のベスト プラクティス: クリーンで効率的で保守可能なコードを作成するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:dev.to
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート