前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >js自己实现map映射的原理

js自己实现map映射的原理

原创
作者头像
IT工作者
发布于 2022-05-13 08:42:07
发布于 2022-05-13 08:42:07
5.6K00
代码可运行
举报
文章被收录于专栏:程序技术知识程序技术知识
运行总次数:0
代码可运行
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
    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
运行
AI代码解释
复制
    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 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
前端常见手写面试题(持续更新中)
观察者需要放到被观察者中,被观察者的状态变化需要通知观察者 我变化了 内部也是基于发布订阅模式,收集观察者,状态变化后要主动通知观察者
helloworld1024
2022/10/26
6920
原生 JavaScript 手写数组 API
本文将会先了解数组 API 的用法再模拟实现这些 API ,如果各位大佬觉得有什么不对的地方麻烦指点以下!
小丞同学
2021/08/16
8270
2023前端二面经典手写面试题_2023-02-27
题目描述:有一组版本号如下 ['0.1.1', '2.3.3', '0.302.1', '4.2', '4.3.5', '4.3.4.5']。现在需要对其进行排序,排序的结果为 ['4.3.5','4.3.4.5','2.3.3','0.302.1','0.1.1']
用户10358576
2023/02/27
5700
【吐血整理】前端JavaScript高频手写面试大全,助你查漏补缺
https://segmentfault.com/a/1190000038910420
@超人
2021/02/26
8860
【吐血整理】前端JavaScript高频手写面试大全,助你查漏补缺
49个常用JavaScript方法封装
https://segmentfault.com/a/1190000039220666
@超人
2021/07/29
5940
[第27 期]彻底分清Javascript forEach & map
JavaScript 中,数组的遍历我们肯定都不陌生,最常见的两个便是forEach 和 map。
皮小蛋
2020/03/02
5150
js常用方法和一些封装(1)1.字符串相关2.数组相关
博主在js上已经花费了很长时间,不禁深深地被其轻巧而强大的功能,以及优雅灵活的写法所折服,一直没找到机会来总结一下,最近发现了简书这个不错的平台,正好把学习的东西做一个汇总。 题外话 我始终认为,学习编程最好的方式就是去写,甭管写的怎样,也要去练习。 当初学完了数组,我记得自己是先把里面的每一个方法都敲了一遍,然后反复思考,通过这些方法,我能够做些什么? 很多语法我一开始也是很不理解的,然而在不断地运用过程中,慢慢地就开始明白过来了。只要抓住一个大方向,然后不断地练,就一定能深入理解! 正如国外一个有名的数
剽悍一小兔
2018/05/17
1K0
JS 原生面经从初级到高级【近1.5W字】
1.函数声明有预解析,而且函数声明的优先级高于变量; 2.使用Function构造函数定义函数的方式是一个函数表达式,这种方式会导致解析两次代码,影响性能。第一次解析常规的JavaScript代码,第二次解析传入构造函数的字符串
火狼1
2019/10/23
1.1K0
JS 原生面经从初级到高级【近1.5W字】
高级前端常考手写面试题合集5
方法有很多种,这里提供一种比较简洁的写法,用到了ES10的Object.fromEntries():
helloworld1024
2023/01/09
5160
javaScript 引用类型
    另外还有一种创建对象的方式是使用Object.create()方法,它是一个静态方法。  
用户1197315
2019/12/02
1.2K0
重写常用原生方法
重写call Function.prototype.myCall = function (ctx) { // 不考虑严格模式下的undefined ctx = Object(ctx) || window // 谁调用方法,this就指向谁,比如这里的myCall是test调用的,this就是test // 给ctx添加一个属性originFn,让他指向this,也就是test // 如果执行originFn(),也就是执行test(),而它是ctx调用的,所以this
hss
2022/02/25
8310
手撕常见JS面试题
高阶函数实现AOP(面向切面编程) Function.prototype.before = function (beforefn) { let _self = this; // 缓存原函数的引用 returnfunction () { // 代理函数 beforefn.apply(this, arguments); // 执行前置函数 return _self.apply(this, arguments); // 执行原函数
helloworld1024
2022/10/14
5660
前端面试被问到的js手写面试题汇总
类的继承在几年前是重点内容,有n种继承方式各有优劣,es6普及后越来越不重要,那么多种写法有点『回字有四样写法』的意思,如果还想深入理解的去看红宝书即可,我们目前只实现一种最理想的继承方式。
helloworld1024
2022/11/18
5940
【JS必知必会】高阶函数详解与实战
当大家看到这个面试题的时候,能否在第一时间想到使用高阶函数实现?想到在实际项目开发过程中,用到哪些高级函数?有没有想过自己创造一个高阶函数呢?开始本篇文章的学习
coder_koala
2019/07/30
8260
美团前端二面必会手写面试题汇总
观察者需要放到被观察者中,被观察者的状态变化需要通知观察者 我变化了 内部也是基于发布订阅模式,收集观察者,状态变化后要主动通知观察者
helloworld1024
2022/10/10
3600
前端手写面试题合集
String.prototype.padStart 和 String.prototype.padEnd是ES8中新增的方法,允许将空字符串或其他字符串添加到原始字符串的开头或结尾。我们先看下使用语法:
helloworld1024
2022/12/07
3750
2021JavaScript面试题(最新)不定时更新(2021.11.6更新)
js 一共有六种基本数据类型,分别是 Undefined、Null、Boolean、Number、String,还有在 ES6 中新增的 Symbol 类型。 Symbol 代表创建后独一无二且不可变的数据类型,它的出现我认为主要是为了解决可能出现的全局变量冲突的问题。
全栈程序员站长
2022/09/07
2.7K0
盘点那些 JS 手写题
flat()方法会按照一个可指定的深度递归遍历数组,并将所有元素与遍历到的子数组中的元素合并为一个新数组返回。
用户8921923
2022/10/24
1.5K0
2023前端必会手写面试题整理1
我们说迭代器对象全凭迭代器生成函数帮我们生成。在ES6中,实现一个迭代器生成函数并不是什么难事儿,因为ES6早帮我们考虑好了全套的解决方案,内置了贴心的 生成器 (Generator)供我们使用:
helloworld1024
2023/01/03
5120
前端js手写题经常忘,记录一下
使用时间戳的节流函数会在第一次触发事件时立即执行,以后每过 wait 秒之后才执行一次,并且最后一次触发事件不会被执行
helloworld1024
2022/09/23
1K0
相关推荐
前端常见手写面试题(持续更新中)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档