JavaScript-柯里化

柯里化

  • 當一個函數(shù)有多個參數(shù)的時候先傳遞一部分參數(shù)調(diào)用它(這部分參數(shù)以后永遠不變)
  • 然后返回一個新的函數(shù)接收剩余參數(shù)冗尤,返回結(jié)果
//科里化演示
function checkAge (age){
    let min = 18;
    return age >= min;
}

//普通的純函數(shù)
function checkAge (min,age){
    return age >= min;
}

console.log(checkAge(18,25))
console.log(checkAge(18,26))
console.log(checkAge(18,27))
console.log(checkAge(18,28))
console.log(checkAge(24,29))
console.log(checkAge(24,29))

function checkAge (min){
    return function(age){
        return age >= min;
    }
}


let checkAge18 = checkAge(18);
let checkAge20 = checkAge(20);

console.log(checkAge18(20));
console.log(checkAge20(24));


//es6寫法
let checkAgeEs6 = min => (age => age >= min); 

let checkAgeEs618 = checkAgeEs6(18);
let checkAgeEs620 = checkAgeEs6(20);

console.log(checkAgeEs618(20));
console.log(checkAgeEs620(24));

//當函數(shù)有多個參數(shù)的時候改造為使用一個函數(shù)傳入部分參數(shù)并讓這個函數(shù)返回新的函數(shù)裂七,新的函數(shù)接收剩余參數(shù)并返回處理結(jié)果

tips: 當函數(shù)有多個參數(shù)的時候改造為使用一個函數(shù)傳入部分參數(shù)并讓這個函數(shù)返回新的函數(shù)仓坞,新的函數(shù)接收剩余參數(shù)并返回處理結(jié)果.

lodash中的柯里化方法

  • curry(function)
    • 功能: 創(chuàng)建一個函數(shù)扯躺,該函數(shù)接收一個或多個function的參數(shù),如果function所需要的參數(shù)都被提供則執(zhí)行function 返回執(zhí)行的結(jié)果倍啥,否則繼續(xù)返回該函數(shù)并等待接收剩余參數(shù)
    • 參數(shù): 需要柯里化的函數(shù)
    • 返回值: 柯里化后的函數(shù)
    //lodash 中的 curry 基本使用
const _ = require("lodash");

//一個參數(shù)叫一元函數(shù) 2個叫二元函數(shù) 3個叫三元函數(shù)
function getSum(a,b,c) { 
    return a + b + c;
}

//柯里化把多元函數(shù) 轉(zhuǎn)化為一元函數(shù)

//curry
const curried = _.curry(getSum);

console.log(curried(1)(2)(3));
console.log(curried(1)(2,3));
console.log(curried(1,2)(3));


//柯里化案例

//案例1 判斷一個字符串中有沒有空白字符 
''.match(/\s+/g);
//匹配所有數(shù)組
''.match(/\d+/g);
//普通
function match(reg,str){
    return str.match(reg);
}
//柯里化
const curryMatch = _.curry(function(reg,str){
    return str.match(reg);
});

const haveSpace = curryMatch(/\s+/g);
const haveNumber = curryMatch(/\d+/g);

console.log(haveSpace(" 1 2 3 4 5 6"))
console.log(haveNumber(" 1 2 3 4 5 6"))

//查找數(shù)組中空白字符元素

const filter = _.curry(function(func,array){
    return array.filter(func);
})

const findSpace = filter(haveSpace);

//es6寫法
const filterEs6 = _.curry((func,array) => array.filter(func));

const findSpaceES6 = filter(haveSpace);

console.log(findSpace(['aaaabbbb','a b']));//[ 'a b' ]
console.log(findSpaceES6(['aaaab bbb','a b']));//[ 'aaaab bbb', 'a b' ]

柯里化原理

一個 柯里化的函數(shù)首先會接受一些參數(shù)虽缕,接受了這些參數(shù)之后蒲稳,該函數(shù)并不會立即求值氮趋,而是繼續(xù)返回另外一個函數(shù)伍派,剛才傳入的參數(shù)在函數(shù)形成的閉包中被保存起來。待到函數(shù)被真正需要求值的時候剩胁,之前傳入的所有參數(shù)都會被一次性用于求值

//科里化演示
function checkAge (age){
    let min = 18;
    return age >= min;
}

//普通的純函數(shù)
function checkAge (min,age){
    return age >= min;
}

console.log(checkAge(18,25))
console.log(checkAge(18,26))
console.log(checkAge(18,27))
console.log(checkAge(18,28))
console.log(checkAge(24,29))
console.log(checkAge(24,29))

function checkAge (min){
    return function(age){
        return age >= min;
    }
}


let checkAge18 = checkAge(18);
let checkAge20 = checkAge(20);

console.log(checkAge18(20));
console.log(checkAge20(24));


//es6寫法
let checkAgeEs6 = min => (age => age >= min); 

let checkAgeEs618 = checkAgeEs6(18);
let checkAgeEs620 = checkAgeEs6(20);

console.log(checkAgeEs618(20));
console.log(checkAgeEs620(24));

//當函數(shù)有多個參數(shù)的時候改造為使用一個函數(shù)傳入部分參數(shù)并讓這個函數(shù)返回新的函數(shù)诉植,新的函數(shù)接收剩余參數(shù)并返回處理結(jié)果

lodash中的科里化

//lodash 中的 curry 基本使用
const _ = require("lodash");

//一個參數(shù)叫一元函數(shù) 2個叫二元函數(shù) 3個叫三元函數(shù)
function getSum(a,b,c) { 
    return a + b + c;
}

//柯里化把多元函數(shù) 轉(zhuǎn)化為一元函數(shù)

//curry
const curried = _.curry(getSum);

console.log(curried(1)(2)(3));
console.log(curried(1)(2,3));
console.log(curried(1,2)(3));


//柯里化案例

//案例1 判斷一個字符串中有沒有空白字符 
''.match(/\s+/g);
//匹配所有數(shù)組
''.match(/\d+/g);
//普通
function match(reg,str){
    return str.match(reg);
}
//柯里化
const curryMatch = _.curry(function(reg,str){
    return str.match(reg);
});

const haveSpace = curryMatch(/\s+/g);
const haveNumber = curryMatch(/\d+/g);

console.log(haveSpace(" 1 2 3 4 5 6"))
console.log(haveNumber(" 1 2 3 4 5 6"))

//查找數(shù)組中空白字符元素

const filter = _.curry(function(func,array){
    return array.filter(func);
})

const findSpace = filter(haveSpace);

//es6寫法
const filterEs6 = _.curry((func,array) => array.filter(func));

const findSpaceES6 = filter(haveSpace);

console.log(findSpace(['aaaabbbb','a b']));//[ 'a b' ]
console.log(findSpaceES6(['aaaab bbb','a b']));//[ 'aaaab bbb', 'a b' ]

柯里化原理模擬

function curry (func) {
    return function curriedFn(...args) {
      // 判斷實參和形參的個數(shù) 函數(shù).length 這種寫法獲取函數(shù)參數(shù)長度
      //如果實參的參數(shù)少于形參的長度則返回一個函數(shù)繼續(xù)接受參數(shù)
      //形成閉包保留args 參數(shù)依次疊加 直到 大于或等于形參 不滿足條件 調(diào)用 func(...args)
      if (args.length < func.length) {
        return function (...args2) {
          return curriedFn(...args.concat(args2))
        }
      }
      //如果函數(shù)的實參和形參個數(shù)相同直接調(diào)用需要柯里化函數(shù)并返回結(jié)果
      return func(...args)
    }
}

柯里化總結(jié):

  • 柯里化可以讓我們給一個函數(shù)傳遞較少的參數(shù)得到一個已經(jīng)記住了某些固定參數(shù)的新函數(shù)
  • 這是一種對函數(shù)參數(shù)的'緩存'
  • 讓函數(shù)變的更靈活,讓函數(shù)的粒度更小
  • 可以把多元函數(shù)轉(zhuǎn)換成一元函數(shù)昵观,可以組合使用函數(shù)產(chǎn)生強大的功能

原文地址: https://kspf.xyz/archives/69/

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末晾腔,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子啊犬,更是在濱河造成了極大的恐慌,老刑警劉巖觉至,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件剔应,死亡現(xiàn)場離奇詭異,居然都是意外死亡语御,警方通過查閱死者的電腦和手機峻贮,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來应闯,“玉大人月洛,你說我怎么就攤上這事∧踝叮” “怎么了?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵细层,是天一觀的道長惜辑。 經(jīng)常有香客問我,道長疫赎,這世上最難降的妖魔是什么盛撑? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮捧搞,結(jié)果婚禮上抵卫,老公的妹妹穿的比我還像新娘。我一直安慰自己胎撇,他們只是感情好介粘,可當我...
    茶點故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著晚树,像睡著了一般姻采。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上爵憎,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天慨亲,我揣著相機與錄音婚瓜,去河邊找鬼。 笑死刑棵,一個胖子當著我的面吹牛巴刻,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播蛉签,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼胡陪,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了正蛙?” 一聲冷哼從身側(cè)響起督弓,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎乒验,沒想到半個月后愚隧,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡锻全,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年狂塘,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片鳄厌。...
    茶點故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡荞胡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出了嚎,到底是詐尸還是另有隱情泪漂,我是刑警寧澤,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布歪泳,位于F島的核電站萝勤,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏呐伞。R本人自食惡果不足惜敌卓,卻給世界環(huán)境...
    茶點故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望伶氢。 院中可真熱鬧趟径,春花似錦、人聲如沸癣防。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蕾盯。三九已至惧蛹,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背香嗓。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工迅腔, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人靠娱。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓沧烈,卻偏偏與公主長得像,于是被迫代替她去往敵國和親像云。 傳聞我的和親對象是個殘疾皇子锌雀,可洞房花燭夜當晚...
    茶點故事閱讀 44,955評論 2 355

推薦閱讀更多精彩內(nèi)容