亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript函數式編程實例分析

2019-11-20 12:36:26
字體:
來源:轉載
供稿:網友

本文實例講述了javascript函數式編程。分享給大家供大家參考。具體分析如下:

js像其他動態語言一樣是可以寫高階函數的,所謂高階函數是可以操作函數的函數。因為在js中函數是一個徹徹底底的對象,屬于第一類公民,這提供了函數式編程的先決條件。

下面給出一個例子代碼,出自一本js教程,功能是計算數組元素的平均值和標準差,先列出非函數式編程的一種寫法:

var data = [1,1,3,5,5];var total = 0;for(var i = 0;i < data.length;i++)  total += data[i];var mean = tatal/data.length; //平均數為3//計算標準差total = 0;for(var i = 0;i < data.length;i++){  var deviation = data[i] - mean;  tatal += deviation * deviation;  }var stddev = Math,.sqrt(total/(data.length-1));//標準差為2

為了使用函數式編程,我們預先定義一些幫助函數(helper functions):

//將類數組對象轉換為真正的數組function array(a,n){ return Array.prototype.slice.call(a,n||0);}//將函數實參傳遞至左側function partial_left(f){ var args = arguments; return function(){  var a = array(args,1);  a = a.concat(array(arguments));  return f.apply(this,a); };}//將函數的實參傳遞至右側function partial_right(f){ var args = arguments; return function(){  var a = array(arguments);  a = a.concat(array(args,1));  return f.apply(this,a); };}//該函數實參被用做模版,//實參列表中的undefined值會被實際實參值填充。function partial(f){ var args = arguments; return function(){  var a = array(args,1);  var i = 0,j = 0;  for(;i<a.length;i++)   if(a[i] === undefined)    a[i] = arguments[j++];  a = a.concat(array(arguments,j));  return f.apply(this,a); };}//返回一個函數類似于f(g())function compose(f,g){ return function(){  return f.call(this,g.apply(this,arguments)); };}

下面我們給出完全用函數式編程的js代碼:

var data = [1,1,3,5,5];var sum = function(x,y){return x+y;};var product = function(x,y){return x*y;};var neg = partial(product,-1);var square = partial(Math.pow,undefined,2);var sqrt = partial(Math.pow,undefined,0.5);var reciprocal = partial(Math.pow,undefined,-1);//好吧,高潮來鳥 :)var mean = product(reduce(data,sum),reciprocal(data.length));var stddev = sqrt(product(reduce(map(data,compose(square,partial(sum,neg(mean)))),sum),reciprocal(sum(data.length,-1))));

除了reduce和map函數,其他函數前面都給出了。reduce函數類似與ruby中的inject函數:

ary = (1..10).to_aary.inject(0) {|sum,i|sum + i} //結果為55

js的寫法如下:

var ary = [1,2,3,4,5,6,7,8,9,10]ary.reduce(function(sum,i){ return sum + i;},0);

0為sum的初始值,如果省略則sum為數組第一個元素的值,這里可以省略。

map函數也很簡單,類似與對數組的每一個元素做操作,然后返回一個經過操作后的數組,就以ruby代碼為例,js代碼與此類似:

a = (1..3).to_a; #數組[1,2,3]a.map {|x| x*2} #返回新數組[2,4,6]

下面我們來分析下那一長串的代碼:)

sum和product定義了元素相加和相乘的函數;

neg也是一個函數功能等價于:product(-1,x),即對x值求負;

square函數等價于:Math.pow(x,2),即計算x的平方值,注意這里partial的第二個參數是undefined,這意味著這里的形參會被第一個實參填補;再說的明白點:square(x)功能等于Math.pow(x,2)。

sqrt函數和square類似,功能等價于:Math.pow(x,0.5),相當于計算x的開二次方。
最后一個函數reciprocal也沒什么難度,等價于:Math.pow(x,-1),即計算x的負一次方,相當于計算x的倒數。

下面就是如何把上面各種函數揉捏在一起鳥 :)

先看平均值的計算,很簡單:就是先計算數組元素的和然后乘上數組長度的倒數,即數組和/數組長度。

最后來看貌似很難的標準差,我們最好由內向外看:
先看包含neg的那層:

//等價于函數sum(-1 * mean + x)partial(sum,neg(mean)

下面看compose函數:

//下面在源代碼上做了等價替換,可以再次等價于://square(sum(-1*mean + x)),再次展開(我剝,我剝,我剝洋蔥...)://Math.pow(sum(-1*mean + x),2);compose(square,sum(-1*mean + x))

接下來看map函數:

//很清楚吧!?即data中每一個元素都為一個x,將其傳入后面的函數,然后返回一個計算后的新數組,即新數組中的每個元素的值是data中的每個元素加上data負的平均數,然后對其結果計算2次方的結果。

map(data,Math.pow(sum(-1*mean + x),2))

再接著看map外面的reduce函數:

//將前面新數組的每個元素值加起來。reduce(map(...),sum)

然后看一下reciprocal函數:

//等價于求(data.length-1)的倒數reciprocal(sum(data.length,-1))

再看外層的product函數:

//等價于新數組元素的和除以(data.length-1)product(reduce(...),reciprocal(...))

最外層的sqrt表示對以上除法得出的結果求平方根;大家可以對照一下前面非函數編程的代碼,是一樣一樣滴 :) 看似蠻怕人的一大坨代碼,展開分析后難度立馬將至零。如果各位看官最后表示還是未看明白,那完全是本貓語言表達能力的問題,歡迎提問。

解釋完畢,打完收功,大功告成。

希望本文所述對大家的javascript程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人精品免费视频| 欧美大片免费观看在线观看网站推荐| 日韩中文在线中文网三级| 久久久精品国产网站| 国产欧美一区二区三区久久人妖| 成人黄色短视频在线观看| 45www国产精品网站| 久久夜精品va视频免费观看| 国产视频精品自拍| 亚洲二区中文字幕| 亚洲精品欧美一区二区三区| 91精品国产91久久久久久最新| 国产aaa精品| 久久综合免费视频影院| 欧美国产日韩中文字幕在线| 亚洲国产成人精品电影| 久久久久这里只有精品| 国语自产精品视频在线看抢先版图片| 久久久国产精品免费| 日韩中文字幕视频在线观看| 日韩亚洲欧美中文在线| 国产精品免费视频久久久| 欧美性极品少妇精品网站| 成人精品在线视频| 精品久久久久久久久久ntr影视| 97超碰国产精品女人人人爽| 亚洲高清一二三区| 亚洲乱码一区二区| 亚洲欧美日韩久久久久久| 亚洲japanese制服美女| 奇米4444一区二区三区| 蜜月aⅴ免费一区二区三区| 亚洲欧美国产精品久久久久久久| 中文字幕久精品免费视频| 久久免费视频观看| 精品成人在线视频| 国产免费一区二区三区在线观看| 最近2019中文字幕一页二页| 亚洲无av在线中文字幕| 91久久久久久久久久久| 日本电影亚洲天堂| 亚洲午夜久久久久久久| 亚洲桃花岛网站| 国产精品日韩精品| 亚洲另类图片色| 日韩av观看网址| 欧美国产日韩二区| 国产精彩精品视频| 日韩一区二区精品视频| 精品久久久久久中文字幕大豆网| 亚洲国产欧美一区二区三区久久| 亚洲精品乱码久久久久久金桔影视| 韩国精品久久久999| 国产精品久久久久影院日本| 另类美女黄大片| 伊人久久综合97精品| 成人h片在线播放免费网站| 国产视频精品自拍| 懂色av影视一区二区三区| 国产日韩欧美成人| 亚洲aa中文字幕| 国产日本欧美一区二区三区| 97视频在线免费观看| 欧美电影在线播放| 欧美激情第6页| 欧美午夜精品久久久久久人妖| 欧美午夜性色大片在线观看| 欧美成人免费大片| 中文字幕在线看视频国产欧美| 欧美黑人一级爽快片淫片高清| 精品久久久久久久久久久久久| 另类专区欧美制服同性| 国产精品视频网站| 日韩精品免费综合视频在线播放| 欧美日韩国产精品一区二区三区四区| 欧美日韩国产专区| 亚洲天堂免费视频| 操日韩av在线电影| 欧美中文字幕在线观看| 国产精品久久久久免费a∨大胸| 国产日本欧美一区二区三区在线| 久久国产加勒比精品无码| 亚洲tv在线观看| 日韩美女视频中文字幕| 欧美激情在线观看| 久久不射热爱视频精品| 成人亚洲欧美一区二区三区| 日韩av在线资源| 欧美视频二区36p| 久久久av免费| 国产丝袜精品第一页| 亚洲人成在线播放| 成人激情av在线| 欧美高跟鞋交xxxxxhd| 国产精品尤物福利片在线观看| 久青草国产97香蕉在线视频| 91sa在线看| 91中文在线观看| 久久精品国产免费观看| 国产精品久久久久久久久影视| 久久久久久综合网天天| 色一区av在线| 日韩精品视频免费专区在线播放| 国语自产精品视频在免费| 国产精品久久久久久久app| 日本一区二区在线免费播放| 亚洲国产日韩欧美在线图片| 欧美大全免费观看电视剧大泉洋| 久久九九亚洲综合| 亚洲乱码av中文一区二区| 成人网页在线免费观看| 久久精品亚洲94久久精品| 国产精品久久在线观看| 久久精品国产91精品亚洲| 91精品国产自产在线老师啪| 中文字幕亚洲精品| 亚洲a在线播放| 日韩动漫免费观看电视剧高清| 欧美极品在线视频| 亚洲精品视频二区| 成人免费淫片视频软件| 亚洲成色www8888| 91九色蝌蚪国产| 精品国产一区久久久| 欧美性在线视频| 久久久免费观看| 69av在线播放| 国产美女扒开尿口久久久| 日韩一中文字幕| 久久久国产精品视频| 精品久久中文字幕久久av| 国产福利精品av综合导导航| 成人欧美一区二区三区黑人孕妇| 亚洲成年人影院在线| 青青草成人在线| 98精品国产自产在线观看| 成人av在线亚洲| 精品国产区一区二区三区在线观看| 8050国产精品久久久久久| 久久精品国产亚洲精品2020| 色视频www在线播放国产成人| 欧美精品性视频| 国产一区二区黄| 国产精品91久久久久久| 亚洲新中文字幕| 高清欧美电影在线| 4438全国亚洲精品在线观看视频| 亚洲无限乱码一二三四麻| 懂色av一区二区三区| 亚洲美女在线视频| 国产精品久久久久久久久久久新郎| 国产精品久久精品| 亚洲国产精品久久91精品| 久久伊人色综合| 国产精品福利在线| 亚洲国产精品一区二区三区| 欧美激情一级欧美精品| 欧美性色视频在线| 中文字幕亚洲欧美日韩高清| 中文字幕日本欧美| 欧美精品aaa| 日韩国产精品一区| 日韩欧美在线视频免费观看| 日韩av中文字幕在线免费观看|