您好,登錄后才能下訂單哦!
這篇文章主要介紹“怎么實現Js函數curry化”,在日常操作中,相信很多人在怎么實現Js函數curry化問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”怎么實現Js函數curry化”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
關于函數curry化,其實就類似與鏈式調用的思想,通過不斷返回函數,使得可以執行多個'(...args)',在適當的時候返回結果
函數curry化的實現:
泛化的curry化
letsum=function(){
vartotal=0;
for(leti=0,c;c=arguments[i++];){
total+=c;
}
returntotal;
};
letcurry=(fn)=>{
letargs=[];
//不用callee這個屬性,而是直接使用函數名字來調用
returnfunctionnext(){
if(arguments.length===0){
returnfn.apply(this,args);
}
//curry化之后的函數使用方式是,不斷收集參數,認為參數收集完畢之后就進行一次無參調用進行最后的計算。
//所以curry化在這里的作用其實就是收集參數,當然不同的curry函數可以達到不同的效果
args=[...args,...arguments];
//returnarguments.callee;
returnnext;
}
}
letsum_curry1=curry(sum);
sum_curry1(1)(2,3);
sum_curry1(4);
console.log(sum_curry1());
curry化的作用
提高適用性
【通用函數】解決了兼容性問題,但同時也會再來,使用的不便利性,不同的應用場景往,要傳遞很多參數,以達到解決特定問題的目的。有時候應用中,同一種規則可能會反復使用,這就可能會造成代碼的重復性。
看下面一個例子:
functionsquare(i){
returni*i;
}
functiondubble(i){
returni*=2;
}
functionmap(handeler,list){
returnlist.map(handeler);
}
到此,關于“怎么實現Js函數curry化”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。