柯里化可變參數求和函數:探索其內部工作原理
在JavaScript 中,建立一個接受多個參數並在柯里化中工作的求和函數方式似乎是一項難以克服的任務。然而,透過柯里化技術確實是可能的。
柯里化涉及將一個採用多個參數的函數轉換為一系列函數,每個函數採用一個參數。這使我們能夠創建一個可以連續應用來添加多個數字的求和函數。
秘密在於我們定義函數的方式:
function sum(n) { var v = function(x) { return sum(n + x); };
這裡, sum(n)傳回一個函數 v,該函數接受一個參數 x 並傳回使用 n x 呼叫 sum 的結果。這允許我們連結多個對 sum 的調用,每次將下一個數字添加到前一個結果。
為了處理最終結果,我們定義函數的 valueOf 和 toString 方法:
v.valueOf = v.toString = function() { return n; };
這確保了當我們呼叫 v 作為值時,它會傳回累加和 n。
最後,我們使用一元加運算子 ( ) 來轉換結果將柯里化函數轉換為原始數字。
console.log(+sum(1)(2)(3)(4));
這將輸出預期結果:10。
因此,雖然乍一看似乎違反直覺,但在 JavaScript 中創建一個可變參數柯里化求和函數是可以使用柯里化原理和函數屬性的巧妙操作。
以上是JavaScript 中的柯里求和函數如何處理多個參數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!