导航


HTML

CSS

JavaScript

浏览器 & 网络

版本管理

框架

构建工具

TypeScript

性能优化

软实力

算法

UI、组件库

Node

冷门技能

forEach

原生

var arr = [
  {
    name: 'Lance',
    age: 20,
  },
  {
    name: 'GC',
    age: 23
  },
  {
    name: 'Shank',
    age: 25
  }
];

var obj = {
  name: 'Lance',
  age: 23
}

arr.forEach(function(value, index, arr) {
  console.log(this); // 默认window
  console.log(value, index, arr);
}, obj);

Untitled

实现

Array.prototype.myForEach = function(cb) {
	var _arr = this,
      _len = _arr.length,
      _caller = arguments[1] || window;

  for (var i = 0; i < _len; i++) {
  	cb.call(_caller, _arr[i], i, _arr);
  }
}

map

原生

var arr = [
  {
    name: 'Lance',
    age: 20,
  },
  {
    name: 'GC',
    age: 23
  },
  {
    name: 'Shank',
    age: 25
  }
];

var obj = {
  name: 'Lance',
  age: 23
}

var newArr = arr.map(function(item, index, arr) {
  item.name = this.name;
  return item; // 必须返回,否则数组里边成员都是 undefined
}, obj);
console.log(newArr, arr);

Untitled

实现

Array.prototype.myMap = function(cb) {
	var _arr = this,
      _len = _arr.length,
      _caller = arguments[1] || window,
      newArr = [];

  for (var i = 0; i < _len; i++) {
    // var item = deepClone(_arr[i]); // 如果要实现深拷贝,可以加此行代码,同时把下边 _arr[i] 替换为 item
  	newArr.push(cb.call(_caller, _arr[i], i, _arr));
  }

  return newArr;
}

filter

原生

var arr = [
  {
    name: 'Lance',
    age: 20,
  },
  {
    name: 'GC',
    age: 23
  },
  {
    name: 'Shank',
    age: 25
  }
];

var obj = {
  name: 'Lance',
  age: 23
}

var newArr = arr.filter(function(item, index, arr) {
  console.log(item, index, arr, this);
  return item.age > 20;
}, obj);
console.log(newArr, arr);

实现

Array.prototype.myFilter = function(cb) {
	var _arr = this,
      _len = _arr.length,
      _caller = arguments[1] || window,
      newArr = [];

  for (var i = 0; i < _len; i++) {
    // var item = deepClone(_arr[i]); // 如果要实现深拷贝,可以加此行代码,同时把下边 _arr[i] 替换为 item
  	cb.call(_caller, _arr[i], i, _arr) && newArr.push(_arr[i]);
  }

  return newArr;
}

reduce

原生

var arr = [
  {
    name: 'Lance',
    age: 20,
  },
  {
    name: 'GC',
    age: 23
  },
  {
    name: 'Shank',
    age: 25
  }
];

var obj = {
  name: 'Lance',
  age: 23
}

var newArr = arr.reduce(function(pre, item, index, arr) {
	item.age >= 23 && pre.push(item);
  return pre;
}, []);
console.log(newArr);

实现

Array.prototype.myReduce = function(cb, initialValue) {
	var _arr = this,
      _len = _arr.length,
      _caller = window;

  for(var i = 0; i < _len; i++) {
    // var item = deepClone(_arr[i]); // 如果要实现深拷贝,可以加此行代码,同时把下边 _arr[i] 替换为 item
  	initialValue = cb.call(_caller, initialValue, _arr[i], i, _arr);
  }

  return initialValue;
};

reduceRight

原生

var arr = [
  {
    name: 'Lance',
    age: 20,
  },
  {
    name: 'GC',
    age: 23
  },
  {
    name: 'Shank',
    age: 25
  }
];

var obj = {
  name: 'Lance',
  age: 23
}

var newArr = arr.reduceRight(function(pre, item, index, arr) {
	item.age >= 23 && pre.push(item);
  return pre;
}, []);
console.log(newArr);

实现

Array.prototype.myReduceRight = function(cb, initialValue) {
	var _arr = this,
      _len = _arr.length,
      _caller = window;

  for(var i = _len - 1; i >= 0; i--) {
    // var item = deepClone(_arr[i]); // 如果要实现深拷贝,可以加此行代码,同时把下边 _arr[i] 替换为 item
  	initialValue = cb.call(_caller, initialValue, _arr[i], i, _arr);
  }

  return initialValue;
};

every

原生

var arr = [
  {
    name: 'Lance',
    age: 20,
  },
  {
    name: 'GC',
    age: 23
  },
  {
    name: 'Shank',
    age: 25
  }
];

var obj = {
  name: 'Lance',
  age: 23
}

var res = arr.every(function(item, index, arr) {
  return item.age < 23;
}, obj);
console.log(res);

实现

Array.prototype.myEvery = function(cb) {
	var _arr = this,
      _len = _arr.length,
      _caller = arguments[1] || window;

  for (var i = 0; i < _len; i++) {
    // var item = deepClone(_arr[i]); // 如果要实现深拷贝,可以加此行代码,同时把下边 _arr[i] 替换为 item
  	if (!cb.call(_caller, _arr[i], i, _arr)) {
    	return false;
    }
  }
  return true;
};

some

原生

var arr = [
  {
    name: 'Lance',
    age: 20,
  },
  {
    name: 'GC',
    age: 23
  },
  {
    name: 'Shank',
    age: 25
  }
];

var obj = {
  name: 'Lance',
  age: 23
}

var res = arr.some(function(item, index, arr) {
  return item.age <= 20;
}, obj);
console.log(res);

实现

Array.prototype.mySome = function(cb) {
	var _arr = this,
      _len = _arr.length,
      _caller = arguments[1] || window;

  for (var i = 0; i < _len; i++) {
    // var item = deepClone(_arr[i]); // 如果要实现深拷贝,可以加此行代码,同时把下边 _arr[i] 替换为 item
  	if (cb.call(_caller, _arr[i], i, _arr)) {
    	return true;
    }
  }

  return false;
}