給定一個函數(shù) fn,返回一個與原始函數(shù)相同的新函數(shù),除了它確保 fn 最多被調(diào)用一次。
第一次調(diào)用返回的函數(shù)時,它應(yīng)該返回與 fn 相同的結(jié)果。
隨后每次調(diào)用它時,它都應(yīng)該返回未定義。
示例1:
輸入:
fn = (a,b,c) => (a + b + c), 調(diào)用 = [[1,2,3],[2,3,6]]
輸出:
**explanation:**
登錄后復制
const oncefn = once(fn);
一次fn(1,2,3); // 6
一次fn(2,3,6); // 未定義,fn 未被調(diào)用
**example 2:** **input:** ```fn = (a,b,c) => (a * b * c), calls = [[5,7,4],[2,3,6],[4,6,8]]``` **output:** ```[{"calls":1,"value":140}]``` **explanation:**
登錄后復制
const oncefn = once(fn);
一次fn(5,7,4); // 140
一次fn(2,3,6); // 未定義,fn 未被調(diào)用
一次fn(4,6,8); // 未定義,fn 未被調(diào)用
**constraints:** `calls` is a valid json array
登錄后復制
1
1
2
*Solution* In this case, we are required to create a higher-order function(a function that returns another function) [Read more about high-order functions here](https://www.freecodecamp.org/news/higher-order-functions-explained/#:~:text=JavaScript%20offers%20a%20powerful%20feature,even%20return%20functions%20as%20results.) We should make sure that the original function `fn` is only called once regardless of how many times the second function is called. If the function fn has been not called, we should call the function `fn` with the provided arguments `args`. Else, we should return `undefined` _Code solution_ ``` sh /** * @param {Function} fn * @return {Function} */ var once = function (fn) { // if function === called return undefined, // else call fn with provide arguments let executed = false; let result; return function (...args) { if (!executed) { executed = true; result = fn(...args); return result; } else { return undefined; } } }; /** * let fn = (a,b,c) => (a + b + c) * let onceFn = once(fn) * * onceFn(1,2,3); // 6 * onceFn(2,3,6); // returns undefined without calling fn */
登錄后復制