<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答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:46
        文檔

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

        javascript之典型高階函數應用介紹_javascript技巧:緣由 雖然以前也使用過javascript語言,但終究是為了配合后端寫的一些零零散散的代碼段,更不能說是javascript項目了。很榮幸的是上個月剛到公司正好碰上項目開始推倒重寫,我們team從頭開始做架構和實現,目的很清楚,為了改進和超越前面的版本。這是個
        推薦度:
        導讀javascript之典型高階函數應用介紹_javascript技巧:緣由 雖然以前也使用過javascript語言,但終究是為了配合后端寫的一些零零散散的代碼段,更不能說是javascript項目了。很榮幸的是上個月剛到公司正好碰上項目開始推倒重寫,我們team從頭開始做架構和實現,目的很清楚,為了改進和超越前面的版本。這是個

        緣由
        雖然以前也使用過javascript語言,但終究是為了配合后端寫的一些零零散散的“代碼段”,更不能說是javascript項目了。很榮幸的是上個月剛到公司正好碰上項目開始推倒重寫,我們team從頭開始做架構和實現,目的很清楚,為了改進和超越前面的版本。這是個真正意義上的javascript“項目”,當然服務端不是我們team來負責啦。這也是我真正開始全職使用javascript來編程。由于之前在學校對形式化方法這門課程比較感興趣,而javascript又是函數式語言,因此我想把更多functional的東西用javascript來表現一下。

        幾個函數
        這幾個方法均為javascript 1.6 數組新增的方法。是很典型的functional 函數,當然也非常實用。下面是functional的定義并不來自javascript。

        filter:接受一個集合Xs(X表示類型,s表示集合),一個謂詞,這個謂詞是從X到bool的映射(函數)。然后過慮這個集合,并返回謂詞為true的元素組成的集合。下面是簡單的實現:
        代碼如下:
        function filter(arr,callback){
        var i,out=[];
        for(i=0;iif(callback(arr[i]))
        out.push(arr[i]);
        }
        return 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);
        };
        var filtered = filter(arr,even);
        console.log(filtered);

        結果:
        2,4,6,8,10
        map:接受一個集合Xs,一個函數f,然后把Xs集合中每一個元素按照順序使用f映射,并返回集合f x1, f x2, f x3 ... f xn。實現如下:
        代碼如下:
        function map(arr,callback){
        var i,l= arr && arr.length || 0,out = new Array(l);
        for(i=0;iout[i]=callback(arr[i]);
        return out;
        }

        測試一下:
        代碼如下:
        var arr = [1,2,3,4,5,6,7,8,9,10];
        var addTen = function(item){
        return item + 10;
        };
        var mapAdded = map(arr,addTen);
        console.log(mapAdded);

        結果:
        11,12,13,14,15,16,17,18,19,20
        另外還有forEach,every和some三個函數在javascript 1.6中出現。但在使用過程中感覺還是缺少一個有力的函數,它就是折疊函數(fold)。正所謂map-reduce,有了map而沒有"reduce"豈不是很掃興?下面就來看看這個”reduce“。

        Reduce的實現
        上面說的reduce其實也就是折疊函數(fold)。它接受一個Xs集合,一個二元操作符f。然后將f插入到集合中的每兩個相鄰元素之間。舉個例子,fold plus [1,2,3,4] 意即 1+2+3+4。為了更加精確,通常需要一個”起始元素“作為f最開始時的第二個參數。例如 fold plus [1,2,3,4] 意即 (1+(2+(3+(4+0)))。下面是實現:
        代碼如下:
        function fold(arr,callback,b){
        var i,x;
        if(b) x=b,i=0;
        else x=arr[0],i=1;
        for(;ix=callback(arr[i],x);
        return x;
        }

        測試:
        代碼如下:
        var arr = [1,2,3,4,5,6,7,8,9,10];
        var plus = function(a,b){
        return a+b;
        };
        var foldPlus = fold(arr,plus,0);
        console.log(foldPlus);

        結果:
        55

        這個函數在ECMAScript 5中名字就叫reduce,而函數式里面通常稱做fold而已,這是很形象的名字。
        總結
        其實上面在實現這些functional函數的時候編寫風格并不是函數式的,因為javascript 語言有具有循環語句。如果沒有循環語句呢?留給下一次探索吧。

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

        文檔

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

        javascript之典型高階函數應用介紹_javascript技巧:緣由 雖然以前也使用過javascript語言,但終究是為了配合后端寫的一些零零散散的代碼段,更不能說是javascript項目了。很榮幸的是上個月剛到公司正好碰上項目開始推倒重寫,我們team從頭開始做架構和實現,目的很清楚,為了改進和超越前面的版本。這是個
        推薦度:
        標簽: 使用 應用 函數
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 91av免费在线视频| 午夜在线a亚洲v天堂网2019| gogo免费在线观看| 免费播放春色aⅴ视频| 美女露隐私全部免费直播| 国产精品免费看久久久无码| 亚洲AV无码专区在线电影成人| 在线播放免费播放av片| 激情婷婷成人亚洲综合| 免费成人午夜视频| 久久精品免费大片国产大片| 国产亚洲日韩一区二区三区| 国产在线观看免费视频软件| 精品无码一区二区三区亚洲桃色| 18女人毛片水真多免费| 中文字幕亚洲综合小综合在线 | 亚洲剧场午夜在线观看| 国产精品69白浆在线观看免费| 国产精品亚洲一区二区麻豆| 国产免费人成视频在线观看| 成年免费a级毛片免费看无码| 亚洲熟妇无码一区二区三区导航 | 亚洲综合亚洲国产尤物| 国产卡一卡二卡三免费入口 | 2022国内精品免费福利视频| 亚洲av无码国产精品夜色午夜| 99re热精品视频国产免费| 亚洲人成网男女大片在线播放| 日本视频免费在线| 黄 色一级 成 人网站免费| 亚洲国产高清在线| 麻豆成人精品国产免费| 二个人看的www免费视频| 亚洲伊人久久大香线蕉在观| 亚洲AV无码乱码在线观看| 久久成人免费电影| 国产天堂亚洲精品| 1区1区3区4区产品亚洲| 男人的天堂亚洲一区二区三区| 又黄又大的激情视频在线观看免费视频社区在线 | 日韩精品视频免费观看|