国产99久久精品_欧美日本韩国一区二区_激情小说综合网_欧美一级二级视频_午夜av电影_日本久久精品视频

最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
當前位置: 首頁 - 科技 - 知識百科 - 正文

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

來源:懂視網 責編:小采 時間:2020-11-27 21:06:33
文檔

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

javascript之典型高階函數應用介紹二_javascript技巧:前言 在前一篇文章javascript之典型高階函數中主要實現了幾個典型的functional函數。文章最后也提出了疑問,為啥那樣的實現與F#之類的函數式語言不太一樣呢?今天來試試更函數式的實現。 另一種實現 同樣地,嘗試對之前實現的函數做一些改動,把fo
推薦度:
導讀javascript之典型高階函數應用介紹二_javascript技巧:前言 在前一篇文章javascript之典型高階函數中主要實現了幾個典型的functional函數。文章最后也提出了疑問,為啥那樣的實現與F#之類的函數式語言不太一樣呢?今天來試試更函數式的實現。 另一種實現 同樣地,嘗試對之前實現的函數做一些改動,把fo

前言
在前一篇文章javascript之典型高階函數中主要實現了幾個典型的functional函數。文章最后也提出了疑問,為啥那樣的實現與F#之類的函數式語言“不太一樣”呢?今天來試試更“函數式”的實現。

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

一個集合要么是空集,要么是一個數與一個集合組成的數對從定義可以看到,每一個集合都可以看作為一個數和一個集合的對。例如:{1,2,4,5} 可以認為是數 1 與 集合{2,4,5} 組成的一對,寫成(1 , {2,4,5})。遞歸地,{2,4,5} 可以看成是(2 , {4,5})。最后即為 (5 , Ø)。按照這樣的理解,我們就可以用遞歸的方法消除循環,因為我們在分解的時候已經訪問了每一個數據項,并且終結條件為空集。下面就看一下filter函數的另一個實現,原函數名加前綴f以區別之前函數:
代碼如下:
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] 這樣消除循環之后,更貼近于數學的歸納定義,顯得更自然。同樣地,再看一下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就做到了這一功能,這也是函數式貼近數學的另外一個明顯的例子。我將在下一篇博客中討論。

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文檔

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

javascript之典型高階函數應用介紹二_javascript技巧:前言 在前一篇文章javascript之典型高階函數中主要實現了幾個典型的functional函數。文章最后也提出了疑問,為啥那樣的實現與F#之類的函數式語言不太一樣呢?今天來試試更函數式的實現。 另一種實現 同樣地,嘗試對之前實現的函數做一些改動,把fo
推薦度:
標簽: 使用 介紹 應用
  • 熱門焦點

最新推薦

猜你喜歡

熱門推薦

專題
Top
主站蜘蛛池模板: 国产成人精品日本亚洲11 | 国产美女视频黄a视频全免费网站 | 国产成人久久久精品一区二区三区 | 3a毛片| 国产精品久久久久久永久牛牛 | 99久久精品国产一区二区小说 | 久久精品国产免费中文 | 亚洲欧洲日本在线观看 | 日韩在线观看第一页 | 国产成人精品一区二区 | 欧美人在线一区二区三区 | 青青伊人91久久福利精品 | 在线欧美视频免费观看国产 | 中文字幕免费在线播放 | 韩国中文字幕 | 国产女人成人精品视频 | 亚洲欧美日韩在线观看播放 | 日本成本人观看免费fc2 | 二区在线播放 | 亚欧一区| 日韩国产欧美一区二区三区在线 | 亚洲色图在线播放 | 欧美精品福利 | 日本成本人观看免费fc2 | 又大又硬又爽 | 亚洲一级毛片免观看 | 特一级大黄在线观看 | 久久亚洲欧美综合激情一区 | 亚洲 国产 日韩 欧美 | 亚洲一区在线播放 | 国内在线观看精品免费视频 | 91精品国产91久久久久福利 | 最新国产精品电影入口 | 日韩欧美一区在线观看 | 国产在线视频资源 | 成人a免费视频播放 | 草湿影院| 国产偷窥在线观看 | 精品在线观看免费 | 全网毛片免费 | 亚洲精品乱码久久久久久 |