Javascript閉包與函數(shù)柯里化淺析
來(lái)源:易賢網(wǎng) 閱讀:691 次 日期:2016-07-18 17:07:44
溫馨提示:易賢網(wǎng)小編為您整理了“Javascript閉包與函數(shù)柯里化淺析”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹Javascript閉包與柯里化,通俗易懂,需要的朋友可以參考下。

閉包和柯里化都是JavaScript經(jīng)常用到而且比較高級(jí)的技巧,所有的函數(shù)式編程語(yǔ)言都支持這兩個(gè)概念,因此,我們想要充分發(fā)揮出JavaScript中的函數(shù)式編程特征,就需要深入的了解這兩個(gè)概念,閉包事實(shí)上更是柯里化所不可缺少的基礎(chǔ)。

一、柯里化的概念

在計(jì)算機(jī)科學(xué)中,柯里化是把接受多個(gè)參數(shù)的函數(shù)變換成接受一個(gè)單一參數(shù)(最初函數(shù)的第一個(gè)參數(shù))的函數(shù),并且返回接受余下的參數(shù)且返回結(jié)果的新函數(shù)的技術(shù)。這個(gè)技術(shù)由Christopher Strachey以邏輯學(xué)家 Haskell Curry 命名的,盡管它是 Moses Schnfinkel 和 Gottlob Frege 發(fā)明的。在直覺(jué)上,柯里化聲稱“如果你固定某些參數(shù),你將得到接受余下參數(shù)的一個(gè)函數(shù)”。所以對(duì)于有兩個(gè)變量的函數(shù)yx,如果固定了y = 2,則得到有一個(gè)變量的函數(shù)2x。

柯里化就是預(yù)先將函數(shù)的某些參數(shù)傳入,得到一個(gè)簡(jiǎn)單的函數(shù)。但是預(yù)先傳入的參數(shù)被保存在閉包中,因此會(huì)有一些奇特的特性。比如:

var adder = function(num){

  return function(y){

     return num + y;

  }

}

var inc = adder(1);

var dec = adder(-1)

這里的inc/dec兩個(gè)變量事實(shí)上是兩個(gè)新的函數(shù),可以通過(guò)括號(hào)來(lái)調(diào)用,比如下例中的用法:

//inc, dec現(xiàn)在是兩個(gè)新的函數(shù),作用是將傳入的參數(shù)值(+/-)1

print(inc(99));//100

print(dec(101));//100

print(adder(100)(2));//102

print(adder(2)(100));//102

二、柯里化的應(yīng)用

根據(jù)柯里化的特性,我們可以寫(xiě)出更有意思的代碼,比如在前端開(kāi)發(fā)中經(jīng)常會(huì)遇到這樣的情況,當(dāng)請(qǐng)求從服務(wù)端返回后,我們需要更新一些特定的頁(yè)面元素,也就是局部刷新的概念。使用局部刷新非常簡(jiǎn)單,但是代碼很容易寫(xiě)成一團(tuán)亂麻。而如果使用柯里化,則可以很大程度上美化我們的代碼,使之更容易維護(hù)。我們來(lái)看一個(gè)例子:

//update會(huì)返回一個(gè)函數(shù),這個(gè)函數(shù)可以設(shè)置id屬性為item的web元素的內(nèi)容

function update(item){

  return function(text){

     $("div#"+item).html(text);

  }

}

//Ajax請(qǐng)求,當(dāng)成功是調(diào)用參數(shù)callback

function refresh(url, callback){

  var params = {

     type : "echo",

     data : ""

  };

  $.ajax({

     type:"post",

     url:url,

     cache:false,

     async:true,

     dataType:"json",

     data:params,

     //當(dāng)異步請(qǐng)求成功時(shí)調(diào)用

     success: function(data, status){

        callback(data);

     },

     //當(dāng)請(qǐng)求出現(xiàn)錯(cuò)誤時(shí)調(diào)用

     error: function(err){

        alert("error : "+err);

     }

  });

}

refresh("action.do?target=news", update("newsPanel"));

refresh("action.do?target=articles", update("articlePanel"));

refresh("action.do?target=pictures", update("picturePanel"));

其中,update函數(shù)即為柯里化的一個(gè)實(shí)例,它會(huì)返回一個(gè)函數(shù),即:

update("newsPanel") = function(text){

  $("div#newsPanel").html(text);

}

由于update(“newsPanel”)的返回值為一個(gè)函數(shù),需要的參數(shù)為一個(gè)字符串,因此在refresh的Ajax調(diào)用中,當(dāng)success時(shí),會(huì)給callback傳入服務(wù)器端返回的數(shù)據(jù)信息,從而實(shí)現(xiàn)newsPanel面板的刷新,其他的文章面板articlePanel,圖片面板picturePanel的刷新均采取這種方式,這樣,代碼的可讀性,可維護(hù)性均得到了提高。

以上就是本文的全部?jī)?nèi)容

更多信息請(qǐng)查看網(wǎng)絡(luò)編程
易賢網(wǎng)手機(jī)網(wǎng)站地址:Javascript閉包與函數(shù)柯里化淺析
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)