JavaScript中ES5如何实现数组map方法

发布时间:2022-03-18 10:07:02 作者:小新
来源:亿速云 阅读:409

JavaScript中ES5如何实现数组map方法

在ES5中,我们可以通过原型扩展的方式自行实现数组的map方法。以下是实现原理和代码示例:

实现原理

  1. 检查调用者是否为数组
  2. 创建一个新数组用于存放结果
  3. 遍历原数组的每个元素
  4. 对每个元素执行回调函数
  5. 将回调结果存入新数组
  6. 返回新数组

代码实现

Array.prototype.myMap = function(callback, thisArg) {
  if (this == null) {
    throw new TypeError('this is null or not defined');
  }
  if (typeof callback !== 'function') {
    throw new TypeError(callback + ' is not a function');
  }
  
  var O = Object(this);
  var len = O.length >>> 0;
  var A = new Array(len);
  
  for (var k = 0; k < len; k++) {
    if (k in O) {
      var kValue = O[k];
      var mappedValue = callback.call(thisArg, kValue, k, O);
      A[k] = mappedValue;
    }
  }
  
  return A;
};

使用示例

var arr = [1, 2, 3];
var newArr = arr.myMap(function(item) {
  return item * 2;
});
console.log(newArr); // [2, 4, 6]

这个实现考虑了边界情况,如空值检查、回调函数验证等,与原生map方法行为基本一致。

推荐阅读:
  1. Javascript如何实现没有map()的映射数组
  2. 怎么在JavaScript中利用map创建数组

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

javascript es5 map

上一篇:HTML如何匹配所有作为第一个子元素

下一篇:CSS类选择器怎么应用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》