亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript之典型高階函數應用介紹二

 更新時間:2013年01月10日 09:00:41   作者:  
在前一篇文章javascript之典型高階函數中主要實現了幾個典型的functional函數,文章最后也提出了疑問,為啥那樣的實現與F#之類的函數式語言“不太一樣”呢?今天來試試更“函數式”的實現
前言
在前一篇文章javascript之典型高階函數中主要實現了幾個典型的functional函數。文章最后也提出了疑問,為啥那樣的實現與F#之類的函數式語言“不太一樣”呢?今天來試試更“函數式”的實現。

另一種實現
同樣地,嘗試對之前實現的函數做一些改動,把for循環(huán)去掉。如何去掉呢?這里先要引入一個集合的歸納法定義:

一個集合要么是空集,要么是一個數與一個集合組成的數對從定義可以看到,每一個集合都可以看作為一個數和一個集合的對。例如:{1,2,4,5} 可以認為是數 1 與 集合{2,4,5} 組成的一對,寫成(1 , {2,4,5})。遞歸地,{2,4,5} 可以看成是(2 , {4,5})。最后即為 (5 , Ø)。按照這樣的理解,我們就可以用遞歸的方法消除循環(huán),因為我們在分解的時候已經訪問了每一個數據項,并且終結條件為空集。下面就看一下filter函數的另一個實現,原函數名加前綴f以區(qū)別之前函數:
復制代碼 代碼如下:

function ffilter(arr,callback){
var i=arguments[2] || 0,
  out = arguments[3] || [];
if(!arr[i]) return arguments[3];
if(callback(arr[i]))
out.push(arr[i]);
return arguments.callee(arr,callback,++i,out);
}

測試:
復制代碼 代碼如下:

var arr = [1,2,3,4,5,6,7,8,9,10];
var even = function(item){
if(typeof item !== "number") return false;
return !(item & 1);
};
console.log(ffilter(arr,even));

結果:
[2, 4, 6, 8, 10] 這樣消除循環(huán)之后,更貼近于數學的歸納定義,顯得更自然。同樣地,再看一下ffold函數:
復制代碼 代碼如下:

var arr = [1,2,3,4,5,6,7,8,9,10];
var plus = function(a,b){
return a+b;
};
console.log(ffold(arr,plus,3));

結果:
58
其他函數以同樣的方法即可。這樣就感覺更functional 了,但能不能再與數學定義更加接近呢?下一次再嘗試。
==========2013.1.8 更新==================
上面說到了那些寫法能否與數學定義更加接近,下面就嘗試一下使用鏈表。先給出一個定義:
復制代碼 代碼如下:

var node = function(){
this.data = 0;
this.tail = null;
};

再初始化一個鏈表
復制代碼 代碼如下:

var n1 = new node(),n2 = new node(),n3 = new node(),n4 = new node(),n5 = new node();
n1.data=1,n1.tail=n2;
n2.data=2,n2.tail=n3;
n3.data=3,n3.tail=n4;
n4.data=4,n4.tail=n5;
n5.data=5,n5.tail=null;

fold鏈表版本:
復制代碼 代碼如下:

function lfold(head,callback,b){
if(!head) return b;
else return callback(head.data,arguments.callee(head.tail,callback,b));
}

輸出結果:
18
按照之前的定義,一個集合要么是空集,要么是一個“頭”與一個“尾”(集合)組成的數對。每一次調用函數時,分解為head和tail,直到集合為空(寫完上面的lfold函數真心感覺太完美了,簡直就是定義,要是程序都長這樣,注釋都不需要了,真是一種享受)。這樣子算是最接近數學定義的表示了。因為javascript不支持很多函數式語言的match,所以不能“自動”分解,也就不能直接表示歸納定義。

javascript除了以上的一些東西,還可以實現函數式里面的partial,dojo框架里面的hitch就做到了這一功能,這也是函數式貼近數學的另外一個明顯的例子。我將在下一篇博客中討論。

相關文章

  • 微信小程序上傳圖片到php服務器的方法

    微信小程序上傳圖片到php服務器的方法

    這篇文章主要為大家詳細介紹了微信小程序上傳圖片到php服務器的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-05-05
  • JS實現的找零張數最小問題示例

    JS實現的找零張數最小問題示例

    這篇文章主要介紹了JS實現的找零張數最小問題,涉及javascript數學運算相關操作技巧,需要的朋友可以參考下
    2017-11-11
  • 使用typescript類型來實現快排詳情

    使用typescript類型來實現快排詳情

    這篇文章主要介紹了使用typescript類型來實現快排詳情,文章圍繞主題展開詳細的內容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-08-08
  • 詳解JavaScript原生封裝ajax請求和Jquery中的ajax請求

    詳解JavaScript原生封裝ajax請求和Jquery中的ajax請求

    在本篇文章中我們總結了關于JavaScript原生封裝ajax請求和Jquery中的ajax請求的知識點內容,需要的朋友們學習參考下。
    2019-02-02
  • 利用JavaScript實現ISO周日歷

    利用JavaScript實現ISO周日歷

    周日歷是日常生活中不常用到的歷法系統(tǒng),一般用于政府、商務的會計年度或者學校教學日歷中。本文將利用JavaScript制作個簡單的周日歷,感興趣的可嘗試一下
    2022-07-07
  • JavaScript的內置對象Math和字符串詳解

    JavaScript的內置對象Math和字符串詳解

    這篇文章主要為大家介紹了JavaScript的內置對象Math和字符串,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • js改變html的原有內容實現方法

    js改變html的原有內容實現方法

    下面小編就為大家?guī)硪黄猨s改變html的原有內容實現方法。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • webpack自動刷新瀏覽器源碼解析

    webpack自動刷新瀏覽器源碼解析

    Webpack自動刷新瀏覽器是一項非常實用的功能,它可以讓開發(fā)者在編輯代碼時,自動更新瀏覽器,從而節(jié)省大量的時間。那么它是如何實現的呢?
    2023-02-02
  • Mac下使用charles遇到的問題以及解決辦法

    Mac下使用charles遇到的問題以及解決辦法

    本文主要介紹了Mac下使用charles遇到的問題以及解決辦法。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • JS消息彈框alert、confirm、prompt的實現代碼

    JS消息彈框alert、confirm、prompt的實現代碼

    這篇文章主要介紹了JS消息彈框alert、confirm、prompt,文中還給大家介紹了js的三大基礎彈框,結合示例代碼給大家介紹的非常詳細,需要的朋友可以參考下
    2022-09-09

最新評論