前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >js自己实现map映射的原理

js自己实现map映射的原理

原创
作者头像
IT工作者
发布2022-05-13 16:42:07
发布2022-05-13 16:42:07
5.4K00
代码可运行
举报
文章被收录于专栏:程序技术知识程序技术知识
运行总次数:0
代码可运行
代码语言:javascript
代码运行次数:0
复制
    Array.prototype.mymap=function(callback){
        //this指向的是当前对象st
        var arr=this;
        var list=[];
        for(var i=0;i<arr.length;i++){
            list[i]=callback(arr[i],i,arr);
        }
        return list;
    }
    var st=[1,2,3,4,5];
    var obj=st.mymap(function(value,index,array){
        console.log(this);//window
        console.log(value, index, array);//输出值 索引 原数组
        return value*2;
    });
    console.log(obj)//[2, 4, 6, 8, 10]; 

匿名函数里面的this指向window,那么怎么让他指向当前对象呢?

代码语言:javascript
代码运行次数:0
复制
    Array.prototype.mymap=function(callback){
        //this指向的是当前对象st
        var arr=this;
        var list=[];
        for(var i=0;i<arr.length;i++){
            list[i]=callback.apply(arr,[arr[i],i,arr]);
        }
        return list;
    }
    var st=[1,2,3,4,5];
    var obj=st.mymap(function(value,index,array){
        console.log(value, index, array);//输出值 索引 原数组
        console.log(this);//[1, 2, 3, 4, 5]
        return value*2;
    });
    console.log(obj)//[2, 4, 6, 8, 10]; 

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档