柯里化思想

概念

  • 柯里化可以讓我們給函數(shù)傳遞較少的參數(shù)得到一個(gè)已經(jīng)記住的某個(gè)固定參數(shù)的新函數(shù)

  • 這是一種對(duì)函數(shù)參數(shù)的緩存

  • 讓函數(shù)變的更靈活棺牧,讓函數(shù)的粒度更小

  • 可以把多元函數(shù)(指多個(gè)參數(shù))轉(zhuǎn)化成一元函數(shù)(指一個(gè)參數(shù))欢嘿,可以組合使用函數(shù),使其產(chǎn)生強(qiáng)大的功能

    這是一種預(yù)先處理的思想(形成一個(gè)不被釋放的閉包稻轨,把一些信息存儲(chǔ)起來(lái),以后基于作用域鏈,訪問(wèn)到事先存儲(chǔ)的信息羞酗,然后進(jìn)行相關(guān)的處理,所有符合這種模式都被成為柯里化函數(shù))

先來(lái)看看 reduce

數(shù)組 reduce 方法:在遍歷數(shù)組的過(guò)程中紊服,可以積累上一次處理的結(jié)果檀轨,基于上次處理的結(jié)果繼續(xù)遍歷

// array.reduce([callback],[initialValue])
var arr = [10, 20, 30, 40];
var res = arr.reduce(function (result, item, index) {
  // [initialValue] 初始值不傳遞,result默認(rèn)的是數(shù)組第一項(xiàng)欺嗤,然后reduce從數(shù)組第二項(xiàng)開始遍歷
  // 每遍歷一次 回調(diào)函數(shù)被觸發(fā)執(zhí)行一次
  // + result 存儲(chǔ)的是上一次回調(diào)函數(shù)返回的結(jié)果(除了第一次初始值或者數(shù)組第一項(xiàng))
  // + item 當(dāng)前遍歷的一項(xiàng)
  // + index 當(dāng)前遍歷一項(xiàng)的索引
  return item + result;
});

var res2 = arr.reduce((result, item) => {
  // 如果傳遞了初始值参萄,則result第一次的結(jié)果就是初始值,item從數(shù)組第一項(xiàng)開始遍歷
  return item + result;
}, 0);

模擬實(shí)現(xiàn) reduce

Array.prototype.reduceTest = function reduceTest(callback, initial) {
  var self = this; // this =>arr
  var i = 0;
  // callback 必須是函數(shù)
  if (typeof callback !== "function")
    throw new TypeError("callback must be an function");
  // 判斷是否有初始值
  if (typeof initial === "undefined") {
    // 如果沒(méi)有初始值 initial 初始值為 數(shù)組 的第一項(xiàng)煎饼,然后從數(shù)組第二項(xiàng)開始遍歷
    initial = self[0];
    i = 1;
  }
  for (; i < self.length; i++) {
    var item = self[i];
    index = i;
    initial = callback(initial, item, index);
  }
  return initial;
};

用柯里化的思想和 reduce 實(shí)戰(zhàn)一道題目

求和;
var sum = curring(10);
console.log(sum(20));
console.log(sum(20, 30));

function curring(x) {
  // 利用閉包機(jī)制存儲(chǔ)x
  return function (...args) {
    args.unshift(x);
    return args.reduce((result, item) => {
      return result + item;
    });
  };
}

組合函數(shù)

組合函數(shù)是函數(shù)式編程的重要概念讹挎,處理數(shù)據(jù)的函數(shù)就像是管道一樣連接起來(lái),然后數(shù)據(jù)穿過(guò)管道最終得到結(jié)果

const add1 = (x) => x + 1;
const add2 = (x) => x * 3;
const add3 = (x) => x / 2;
// 然后我們構(gòu)建一個(gè)組合函數(shù)
const operat = compose(add1, add2, add3);
operat(0); // 相當(dāng)于 add3(add2(add1(0)))
// 那么這個(gè)compose函數(shù)怎么編寫呢吆玖?

function compose(...funs) {
  return function operat(x) {
    if (funs.length === 0) return x;
    if (funs.length === 1) return funs[0](x);
    // reduce 數(shù)組 從左向右執(zhí)行  reduceRight 數(shù)組從右向左執(zhí)行
    return funs.reduceRight(function (result, item) {
      if (typeof item !== "function") return result;
      return item(result);
    }, x);
  };
}
var operate = compose(div2, mul3, add1);
var result = operate(0);
console.log(result);

// funs :存儲(chǔ)需要指向函數(shù)的順序 最后面的函數(shù)優(yōu)先執(zhí)行
// 執(zhí)行compose 只是把要執(zhí)行的函數(shù)存儲(chǔ)起來(lái)筒溃,還沒(méi)有執(zhí)行
// 返回一個(gè)operat 處理函數(shù),執(zhí)行函數(shù)沾乘,并且傳遞初始值怜奖,才按照之前存儲(chǔ)的順序依次執(zhí)行
// 依舊是用到了閉包的思想

模擬實(shí)現(xiàn)函數(shù)柯里化

function curry(func) {
  return function curried(...args) {
    // 判斷實(shí)參和形參的個(gè)數(shù) 如果參數(shù)大于或者等于,那個(gè)直接執(zhí)行下面的返回函數(shù)把參數(shù)傳進(jìn)去
    // 否則進(jìn)入判斷意鲸,把參數(shù)合并再傳入函數(shù)中烦周,
    if (args.length < func.length) {
      return function () {
        return curried(...args.concat(Array.from(arguments)));
      };
    }
    return func(...args);
  };
}

function getSum(a, b, c) {
  return a + b + c;
}

const curried = curry(getSum);
console.log(curried(1, 2, 3));
console.log(curried(1)(2, 3));

命令式編程和函數(shù)式編程的區(qū)別

命令式編程:自己編寫代碼,管控步驟和邏輯(自己可以靈活掌握步驟)

函數(shù)式編程:具體的實(shí)現(xiàn)步驟已經(jīng)被封裝成方法怎顾,我們只需要調(diào)用方法獲取結(jié)果即可读慎,無(wú)需關(guān)注怎么實(shí)現(xiàn)的。
弊端:無(wú)法靈活掌握?qǐng)?zhí)行的步驟

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末槐雾,一起剝皮案震驚了整個(gè)濱河市夭委,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌募强,老刑警劉巖株灸,帶你破解...
    沈念sama閱讀 216,470評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異擎值,居然都是意外死亡慌烧,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,393評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門鸠儿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)屹蚊,“玉大人厕氨,你說(shuō)我怎么就攤上這事⌒谠粒” “怎么了命斧?”我有些...
    開封第一講書人閱讀 162,577評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)嘱兼。 經(jīng)常有香客問(wèn)我国葬,道長(zhǎng),這世上最難降的妖魔是什么芹壕? 我笑而不...
    開封第一講書人閱讀 58,176評(píng)論 1 292
  • 正文 為了忘掉前任汇四,我火速辦了婚禮,結(jié)果婚禮上哪雕,老公的妹妹穿的比我還像新娘船殉。我一直安慰自己,他們只是感情好斯嚎,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,189評(píng)論 6 388
  • 文/花漫 我一把揭開白布利虫。 她就那樣靜靜地躺著,像睡著了一般堡僻。 火紅的嫁衣襯著肌膚如雪糠惫。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,155評(píng)論 1 299
  • 那天钉疫,我揣著相機(jī)與錄音硼讽,去河邊找鬼。 笑死牲阁,一個(gè)胖子當(dāng)著我的面吹牛固阁,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播城菊,決...
    沈念sama閱讀 40,041評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼备燃,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了凌唬?” 一聲冷哼從身側(cè)響起并齐,我...
    開封第一講書人閱讀 38,903評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎客税,沒(méi)想到半個(gè)月后况褪,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,319評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡更耻,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,539評(píng)論 2 332
  • 正文 我和宋清朗相戀三年测垛,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片秧均。...
    茶點(diǎn)故事閱讀 39,703評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赐纱,死狀恐怖脊奋,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情疙描,我是刑警寧澤,帶...
    沈念sama閱讀 35,417評(píng)論 5 343
  • 正文 年R本政府宣布讶隐,位于F島的核電站起胰,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏巫延。R本人自食惡果不足惜效五,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,013評(píng)論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望炉峰。 院中可真熱鬧畏妖,春花似錦、人聲如沸疼阔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,664評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)婆廊。三九已至迅细,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間淘邻,已是汗流浹背茵典。 一陣腳步聲響...
    開封第一講書人閱讀 32,818評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留宾舅,地道東北人统阿。 一個(gè)月前我還...
    沈念sama閱讀 47,711評(píng)論 2 368
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像筹我,于是被迫代替她去往敵國(guó)和親扶平。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,601評(píng)論 2 353

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

  • 一崎溃、JS引擎的工作原理[https://www.cnblogs.com/onepixel/p/5090799.ht...
    yolkpie閱讀 176評(píng)論 0 0
  • 1. 什么是函數(shù)式編程 1.1 當(dāng)考慮應(yīng)用設(shè)計(jì)時(shí)蜻直,我們應(yīng)該問(wèn)問(wèn)自己是否遵從了以下的設(shè)計(jì)原則? 可擴(kuò)展性一一我是否需...
    zxhnext閱讀 2,440評(píng)論 0 27
  • 編程范式 托馬斯.庫(kù)爾提出“科學(xué)的革命”的范式論后,Robert Floyd在1979年圖靈獎(jiǎng)的頒獎(jiǎng)演說(shuō)中使用了編...
    zhoulujun閱讀 291評(píng)論 0 1
  • [toc] 第一部分 函數(shù)式思想 第 1 章 走近函數(shù)式 函數(shù)式思想什么是函數(shù)式編程以及為什么要進(jìn)行函數(shù)式編程不變...
    TWLESVCNZ閱讀 739評(píng)論 0 1
  • 我是黑夜里大雨紛飛的人啊 1 “又到一年六月袁串,有人笑有人哭概而,有人歡樂(lè)有人憂愁,有人驚喜有人失落囱修,有的覺(jué)得收獲滿滿有...
    陌忘宇閱讀 8,535評(píng)論 28 53