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

首頁 > 語言 > JavaScript > 正文

javascript函數式編程實例分析

2024-05-06 16:18:45
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了javascript函數式編程,實例分析了javascript函數式編程的相關使用技巧,非常具有實用價值,需要的朋友可以參考下

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

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

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

 

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

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

 

 
  1. //將類數組對象轉換為真正的數組 
  2. function array(a,n){ 
  3. return Array.prototype.slice.call(a,n||0); 
  4. //將函數實參傳遞至左側 
  5. function partial_left(f){ 
  6. var args = arguments; 
  7. return function(){ 
  8. var a = array(args,1); 
  9. a = a.concat(array(arguments)); 
  10. return f.apply(this,a); 
  11. }; 
  12. //將函數的實參傳遞至右側 
  13. function partial_right(f){ 
  14. var args = arguments; 
  15. return function(){ 
  16. var a = array(arguments); 
  17. a = a.concat(array(args,1)); 
  18. return f.apply(this,a); 
  19. }; 
  20. //該函數實參被用做模版, 
  21. //實參列表中的undefined值會被實際實參值填充。 
  22. function partial(f){ 
  23. var args = arguments; 
  24. return function(){ 
  25. var a = array(args,1); 
  26. var i = 0,j = 0; 
  27. for(;i<a.length;i++) 
  28. if(a[i] === undefined) 
  29. a[i] = arguments[j++]; 
  30. a = a.concat(array(arguments,j)); 
  31. return f.apply(this,a); 
  32. }; 
  33. //返回一個函數類似于f(g()) 
  34. function compose(f,g){ 
  35. return function(){ 
  36. return f.call(this,g.apply(this,arguments)); 
  37. }; 

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

 

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

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

 

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

js的寫法如下:

 

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

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

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

 

 
  1. a = (1..3).to_a; #數組[1,2,3] 
  2. 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的那層:

 

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

下面看compose函數:

 

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

接下來看map函數:

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

 

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

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

 

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

然后看一下reciprocal函數:

 

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

再看外層的product函數:

 

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

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

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
成年无码av片在线| 日韩av在线网页| 成人免费大片黄在线播放| 欧美日韩一区二区在线播放| 欧美丝袜一区二区三区| 欧美老女人在线视频| 日韩欧美精品中文字幕| 国产一区二区三区精品久久久| 国产91在线视频| 久久高清视频免费| 亚洲美女av电影| 日韩视频第一页| 久久高清视频免费| 欧美xxxx综合视频| 97精品一区二区三区| 久久网福利资源网站| 中文字幕日韩免费视频| 不卡伊人av在线播放| 亚洲欧美激情在线视频| 91麻豆国产语对白在线观看| 欧美成aaa人片在线观看蜜臀| 欧美激情影音先锋| 日韩欧美在线视频免费观看| 日韩一区二区av| 亚洲国产一区二区三区四区| 久久理论片午夜琪琪电影网| 欧美理论片在线观看| 欧美综合国产精品久久丁香| 亚洲精品视频久久| 国产精品久久一| 精品久久中文字幕| 欧美最顶级丰满的aⅴ艳星| 国产成人在线视频| 欧亚精品中文字幕| 国产精品91久久久久久| 欧美中文字幕视频| 亚洲欧美制服第一页| 欧美电影在线观看网站| 免费不卡欧美自拍视频| 国产在线精品自拍| 欧美电影在线观看高清| 精品久久久久久久久久国产| 久久精品成人一区二区三区| 欧美性极品xxxx做受| 日韩欧美国产一区二区| 最近2019中文字幕第三页视频| 国产91色在线免费| 91在线看www| 欧美激情精品久久久久| 国语自产偷拍精品视频偷| 日韩av网站导航| 久久免费视频观看| 亚洲跨种族黑人xxx| 国产91对白在线播放| 亚洲www永久成人夜色| 日韩精品有码在线观看| 欧美亚洲一级片| 久久国产精品久久精品| 欧美亚洲日本黄色| 久久精品一区中文字幕| 欧美日韩国内自拍| 伊人久久久久久久久久久久久| 成人日韩在线电影| 国产日韩综合一区二区性色av| 国产精品成人av性教育| 欧美日韩免费区域视频在线观看| 欧美大学生性色视频| 日韩福利伦理影院免费| 国产视频久久久| 日韩美女免费观看| 国产精品久久在线观看| 久久精品视频免费播放| 另类少妇人与禽zozz0性伦| 国产精品成人va在线观看| 欧美成年人在线观看| 久久人91精品久久久久久不卡| 亚洲国产第一页| 夜色77av精品影院| 97久久精品人人澡人人爽缅北| 色综合导航网站| 久久97久久97精品免视看| 久久国产天堂福利天堂| 成人激情视频在线观看| 亚洲第一av网站| 韩国福利视频一区| 欧美性猛交xxxx黑人猛交| 国产91网红主播在线观看| 福利二区91精品bt7086| 亚洲第一精品夜夜躁人人躁| 亚洲激情 国产| 中文字幕亚洲一区在线观看| 福利视频一区二区| 欧美成人小视频| 亚洲国产日韩欧美在线动漫| 亚洲欧洲第一视频| 91在线观看免费高清| 777精品视频| 日韩av片永久免费网站| 亚洲精品国产拍免费91在线| 97成人在线视频| 久久99亚洲热视| 北条麻妃99精品青青久久| 中文字幕日韩欧美| 在线精品国产成人综合| 深夜精品寂寞黄网站在线观看| 欧美一区二区三区……| 中文字幕av一区二区| 国产精品对白刺激| 亚洲精品一区二区网址| 成人深夜直播免费观看| 92福利视频午夜1000合集在线观看| 久久香蕉国产线看观看网| 成人激情黄色网| 日韩精品中文字幕久久臀| 亚洲国产精品网站| 亚洲精品99久久久久| 日韩一区二区三区xxxx| 亚洲精品成a人在线观看| 国产成人综合久久| 国产精品一区二区电影| 国产91在线高潮白浆在线观看| 亚洲最大福利网| 色哟哟入口国产精品| 久久久久久久久久婷婷| 国产成+人+综合+亚洲欧美丁香花| 岛国av一区二区三区| 中文字幕久久亚洲| 日韩视频欧美视频| 91久久久久久国产精品| 亚洲国产精品yw在线观看| 欧美精品久久一区二区| 国产极品jizzhd欧美| 国产精品国语对白| 一区二区欧美在线| 国产精品69精品一区二区三区| 欧美在线欧美在线| 中文字幕亚洲欧美一区二区三区| 97视频免费观看| 91成品人片a无限观看| 日韩禁在线播放| 亚洲精品免费一区二区三区| 久久香蕉国产线看观看av| 欧美日韩第一页| 亚洲一区久久久| 欧美日韩在线第一页| 亚洲精品丝袜日韩| 午夜精品视频网站| 中文字幕自拍vr一区二区三区| 成人天堂噜噜噜| 亚洲伊人一本大道中文字幕| 日韩中文av在线| 日韩精品一区二区三区第95| 91在线观看免费高清完整版在线观看| 国产91精品久久久久久久| 国产精品免费久久久| 亚洲精品日韩丝袜精品| 一本久久综合亚洲鲁鲁| 亚洲大胆人体视频| 亚洲3p在线观看| 91国产在线精品| 国产97在线亚洲| 亚洲欧洲日本专区| 亚洲午夜精品久久久久久性色| 欧美日韩另类在线|