时间:2021-05-18
昨天使用map方法的时候,突然感觉一直在直接用,也没有试试是怎么实现的,本来想直接搜一篇文章盘一下子,结果没搜到合适的,好吧,那就自己来写一下子吧
今天就来实现一个简单的map方法
首先我们来看一下map方法的使用以及具体的参数
var arr = ["a","b","c","d","e"]; arr.map(function(currentValue,index,arr){ console.log("当前元素"+currentValue) console.log("当前索引"+index) console.log("数组对象"+arr) })map的参数:
currentValue 必须。当前元素的值
index 可选。当期元素的索引值
arr 可选。当期元素属于的数组对象
运行结果:
我们先来屡屡思路,直接Array.map()就可以调用到map方法,那他应该是在原型链上的,然后接收一个匿名函数做参数,通过循环调用传入的匿名函数
下面我们来写一下试试
Array.prototype.newMap = function(fn) { var newArr = []; for(var i = 0; i<this.length; i++){ newArr.push(fn(this[i],i,this)) } return newArr; }来,调用一下试一下子
arr.newMap((currentValue,index,arr)=>{ console.log("newMap当前元素"+currentValue) console.log("newMap当前索引"+index) console.log("newMap数组对象"+arr) })运行结果:
可以看到我们的运行结果是完全一样的,到这里简单的map方法就实现了,可能有一些细节没注意到,没关系,只是给大家一个思路而已
以上就是如何用JS模拟实现数组的map方法的详细内容,更多关于JS模拟实现数组的map方法的资料请关注其它相关文章!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
js原生方法map实现mapArray.prototype.my_map=function(callback){if(!Array.isArray(this)|
复制代码代码如下:/****描述:js实现的map方法*@returns{Map}*/functionMap(){varstruct=function(key,
在这篇文章中,我将向您展示如何用新的Java8forEach语句循环一个List和Map。1、forEach和Map1.1、常规循环Map常用的方法。Mapit
我用这篇文章来理一理如何用js去实现封装jQuery的简单方法。本文js实现了下面jquery的几种方法,我将它分为8个小目标实现$(".box1").clic
Map获取键值Map以按键/数值对的形式存储数据,和数组非常相似,在数组中存在的索引,它们本身也是对象。Map的接口Map---实现MapMap.Entry--