您好,登錄后才能下訂單哦!
小編給大家分享一下JavaScript函數式編程中純函數的案例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
函數式編程中純函數如何理解?
概念: 不依賴執行的上下文,也不影響上下文的變量,輸出只由輸入決定
代碼理解一下
// 綜上,非純函數,輸入依賴外部變量 let b = 1 function unPure(a) { return a + b } // 綜上,非純函數,輸出改變外部變量 let o = {} function unPure(object) { object.ex = 1 return object } // 綜上, 純函數, 輸出輸入不影響外部變量 function pure(a) { let b = 1 return a + b }
相信大家發現了,無論是概念還是代碼理解都很簡單, 那為什么要使用純函數呢? 下面我們羅列一下使用純函數的好處
純函數可以根據輸入來做緩存
// 下面的代碼我們可以發現相同的輸入,再第二次調用的時候都是直接取的緩存 let squareNumber = memoize((x) => { return x*x; }); squareNumber(4); //=> 16 squareNumber(4); // 從緩存中讀取輸入值為 4 的結果 //=> 16 squareNumber(5); //=> 25 squareNumber(5); // 從緩存中讀取輸入值為 5 的結果 //=> 25
怎么實現呢? 我們接著看下面的代碼
const memoize = (f) => { const cache = {}; return () => { var arg_str = JSON.stringify(arguments); // 關鍵就在這里,我們利用純函數相同輸入相同輸出的邏輯,在這里利用cache做一個簡單的緩存,當這個參數之前使用過時,我們立即返回結果就行 cache[arg_str] = cache[arg_str] || f.apply(f, arguments); return cache[arg_str]; }; };
可移植性大白話過來就是,在任何一個地方都可以隨意使用,A項目中使用過的,B項目想要使用直接拿過來就ok的那種
代碼再來理解一下
// 我們注意看下方有兩個注冊的函數 // 不純的, 如果B項目想要用到這個函數,很顯然我們將其依賴的其它服務給搬過去 const signUp = function(attrs) { var user = saveUser(attrs); welcomeUser(user); } // 純的, 我們再來看看下面這個純函數寫法,純函數給了我們足夠多的信息,我們想在B項目使用其功能只需將單個方法搬過去再給其注入需要的參數即可 const signUp = function(Db, Email, attrs) { return function() { var user = saveUser(Db, attrs); welcomeUser(Email, user); }; };
綜上所述,這個就很簡單了,我們不需要關心其它外部的信息,只需要給函數特定的輸入,再斷言其輸出就好了
以上是“JavaScript函數式編程中純函數的案例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。