返回介绍

模拟 Array.prototype.map()

发布于 2024-09-07 20:34:43 字数 1214 浏览 0 评论 0 收藏 0

map() 方法创建一个新数组,其结果是该数组中的每个元素是调用一次提供的函数后的返回值。

语法

var new_array = arr.map(function callback(currentValue[, index[, array]]) {
 // Return element for new_array 
}[, thisArg])

参数

callback

生成新数组元素的函数,使用三个参数:

  • currentValue

    数组中正在处理的当前元素。

  • index 可选

    数组中正在处理的当前元素的索引。

  • array 可选

    map 方法调用的数组。

thisArg 可选

执行 callback 函数时值被用作 this

代码实现

/**
 * map() 方法创建一个新数组,其结果是该数组中的每个元素是调用一次提供的函数后的返回值。
 */
Array.prototype.myMap = function(callback, context) {
  const arr = this,res = []
  const len = arr.length || 0
  let index = 0
  while(index < len) {
    res.push(callback.call(context, arr[index], index))
    index ++
  }
  return res  // 与 forEach 不同的是 map 有返回值
}
const arr = [1,2,3]
let res1 = arr.map((item,index) => {
  return `k:${index}-v:${item}`
})
let res2 = arr.myMap((item,index) => {
  return `k:${index}-v:${item}`
})
console.log(res1) // [ 'k:0-v:1', 'k:1-v:2', 'k:2-v:3' ]
console.log(res2) // [ 'k:0-v:1', 'k:1-v:2', 'k:2-v:3' ]

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文