Debounce 與 Memoize


Posted by 半夏 on 2023-04-11

Debounce

概念

類似搭公車,人都上車了公車才發動~要是發現還有人要上車,公車就會再等一下直到大家都上車。

應用

在搜尋時,等待使用者打完所有要搜尋的字之後,才去打 API 拿資料,減少效能耗損優化效率~
詳細介紹可參考:Debounce – How to Delay a Function in JavaScript (JS ES6 Example)

寫法一
function debounce(fn, delay) {
  let timer = null;
  return function (...args) {
    if (timer) {
      clearTimeout(timer);
    }
    timer = setTimeout(() => fn(...args), delay);
  };
}

寫法二
function debounce(fn, delay = 300){
  let timer;
  return (...args) => {
    clearTimeout(timer);
    timer = setTimeout(() => fn.apply(this, args), delay);
  };
}

Memoize

概念

把複雜的計算記起來,下次就不用再算一次~
類似 React 的 useMemo 跟 Memo 的功能

應用

直接看下面程式碼~
利用一個 Object 儲存運算後的值,如果 Object 內沒有這個值就把它存起來~
有值的話就直接回傳計算後的結果


function memoize(fn) {
  let cached = {};
  return function (n) {
    if (!cached[n]) {
      cached[n] = fn(n);
    }
    return cached[n];
  };
}

參考:第十六週練習題










Related Posts

Python 使用 ElementTree 寫入 XML 格式檔案與縮排

Python 使用 ElementTree 寫入 XML 格式檔案與縮排

[ 筆記 ] 後端基礎 - 資料庫、SQL 語法

[ 筆記 ] 後端基礎 - 資料庫、SQL 語法

從 React 原始碼看 keyPress 與 keyDown 事件

從 React 原始碼看 keyPress 與 keyDown 事件


Comments