手写实数组的高阶方法

<script>

1.手写forEach方法

        let arr = [11, 22, 34, 56, 78, 32, 54]

        console.log('********************forEach**********************');

        function ForEach(arr, callback) {

            for (let i = 0; i < arr.length; i++) {

                callback(arr[i], i)

            }

        }

        ForEach(arr, (item, index) => {

            console.log(index + '--' + item);

        })

2.手写ffter

        console.log('********************filter**********************');

        function filter(arr, callback) {

            let arr2 = []   //定义一个空的数组

            for (let i = 0; i < arr.length; i++) {

                if (callback(arr[i])) {

                    arr2.push(arr[i])

                }

            }

            return arr2

        }

        let arr2 = filter(arr, function (item) {

            return item % 2 === 0

        })

        console.log(arr2);

3.手写find方法

        console.log('********************find**********************');

        function find(arr, callback) {

            for (let i = 0; i < arr.length; i++) {

                if (callback(arr[i])) {

                    return arr[i]

                }

            }

        }

        let num1 = find(arr, function (item) {

            return item % 3 === 0

        })

        console.log(num1);

4.手写findIndex方法

        console.log('********************findIndex**********************');

        function findIndex(arr, callback) {

            for (let i = 0; i < arr.length; i++) {

                if (callback(arr[i])) {

                    return i

                }

            }

            return -1    //找不到返回-1

        }

        let index1 = findIndex(arr, function (item) {

            return item % 3 === 0

        })

        console.log(index1);

5.手写some方法

        console.log('********************some**********************');

        function some(arr, callback) {

            for (let i = 0; i < arr.length; i++) {

                if (callback(arr[i])) {

                    return true

                }

            }

            return false

        }

        let isok1 = some(arr, function (item) {

            return item % 3 === 0

        })

        console.log(isok1);

6.手写every方法

        console.log('********************every**********************');

        function every(arr, callback) {

            for (let i = 0; i < arr.length; i++) {

                if (!callback(arr[i])) {

                    return false

                }

            }

            return true

        }

        let isok2 = every(arr, function (item) {

            return item > 10

        })

        console.log(isok2);

 

        console.log('********************map**********************');

        function map(arr, callback) {

            let arr2 = [] //定义一个新的数组

            for (let i = 0; i < arr.length; i++) {

                arr2.push(callback(arr[i]))

            }

            return arr2

        }

        let arr3 = map(arr, function (item) {

            return item * 2

        })

        console.log(arr3);

8.手写sort方法

        console.log('********************sort**********************');

        function sort(arr, callback) {

            for (let i = 0; i < arr.length - 1; i++) {

                for (let j = i + 1; j < arr.length; j++) {

                    if (callback(arr[i], arr[j]) > 0) {    // 这里的>0就是进行判断前一位大于后一位,或者后一位大于前一位判断是否要进行替换,从而决定升序还是降序,a-b大于0才能得出a大于b也就是等于前一位大于后一位

                        let temp = arr[i]

                        arr[i] = arr[j]

                        arr[j] = temp

                    }

                }

            }

            return arr

        }

        console.log(sort(arr, (a, b) => a - b));   //升序 这里的a=arr[i]

        console.log(sort(arr, (a, b) => b - a));   //降序 这里的b=arr[j]

        console.log('********************reduce**********************');

       9.手写reduce()方法

        function reduce(arr, callback, initNum) {

            let sum = 0 //定义总数

            for (let i = 0; i < arr.length; i++) {

                let r = callback(initNum, arr[i])  //imitNum这里代表的是a的值,arr[i]这里代表的是b的值

                sum = r      //每次返回的结果需要替换sum

                initNum = r  //每次返回的结果,需要替换initNum

            }

            return initNum

        }

        console.log(reduce(arr, (a, b) => a + b, 0));

        console.log('********************reduceRight**********************');

5

        function reduceRight(arr, callback, initNum) {

            for (let i=arr.length-1;i>=0;i--) {

                let r = callback(arr[i],initNum)

                initNum = r  //每次返回的结果,需要替换initNum

            }

            return initNum

        }

        console.log(reduceRight(arr, (a, b) => a + b, 0));

    </script>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,033评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,725评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,473评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,846评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,848评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,691评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,053评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,700评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,856评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,676评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,787评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,430评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,034评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,990评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,218评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,174评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,526评论 2 343

推荐阅读更多精彩内容