js笔记之解析语法糖,Array方法,forEach,map,filter等方法解析

26 篇文章 0 订阅
20 篇文章 1 订阅

语法糖

在JavaScript推出到es5之后,官方语法糖越来越多,官方语法糖就是用语言底层官方自己封装好的方法供开发者使用,今天我就来解析一下Array中比较常用的一些语法糖,如forEach,map等。

forEach解析

想解析其底层原理,先要明白它怎么使用:

var arr = [1, 2, 3];
// forEach可以接收两个参数一个回调函数, 一个是回调中的this
arr.forEach(function (item, index, orgin) { //后调中可以传3个参数一个是遍历出的数组中的每一项,一个是数组的下标,一个是数组本省 
	console.log(item);	// 1 || 2 || 3
	console.log(index); // 0 || 1 || 2
	console.log(orgin); // Array:[1, 2, 3]
	console.log(this);	// Object: {name: 'forEach'}
}, {name: 'forEach'});

好明白了用法,就开始解析,重新封装:

// 首先把方法定义到Array的原型链上,使方法可以供数组实例对象调用
Array.prototype.myForEach = function (callback, myThis) { //可接收两个参数回调和回调中的this
	// 如果没有传第二个参数,回调的this则为window
	var _that = myThis || window;
	for (var index = 0; index < this.length; index ++) { // 底层还是for循环
		// 回调调用时要call一下把要设置的this传进去
		callback.call(_that, this[index], index, this);
	}
}

ok是不是很简单呢,我们来实验一下:

var arr = [1, 2, 3];
arr.forEach(function (item, index, orgin) { 
	console.log(item);	// 1 || 2 || 3
	console.log(index); // 0 || 1 || 2
	console.log(orgin); // Array:[1, 2, 3]
	console.log(this);	// Object: {name: 'myForEach'}
}, {name: 'myForEach'});

这里会不会还有隐藏的bug我没有测试出来,如果哪位大神看出来请拍砖。

filter解析

有了forEach的经验就可以照葫芦画瓢,当然在那之前我们还是先看看filter的具体用法:

  var arr = [1, 2, 3];
  // 在参数上filter与forEach一样,只是filter可以接收一个返回值是一个新的数组,返回值是由后调的返回值决定的
  var newArr = arr.filter(function (item, index, orgin) {
  		console.log(item);	// 1 || 2 || 3
		console.log(index); // 0 || 1 || 2
		console.log(orgin); // Array:[1, 2, 3]
		console.log(this);	// Object: {name: 'filter'}
	   	return item > 1; 	// 这里为true时就会把数组的该属性push到新数组中最后由filter返回出去
  }, {name: 'filter'});
  console.log(newArr); // [2, 3] 大于1的属性

PS(filter的返回值不是深度拷贝,所以当数组的属性有引用值时,返回数组中有变化原数组也会跟着变化,开发者们注意喽)
ok明白了用法我们来,照葫芦画瓢:

   Array.prototype.myFilter = function (callback, myThis) {
   	  // 判断是否穿了相应的回调this, 创建新的数组用于方法返回值
      var _that = myThis || window, newArr = [];
        for (var index = 0; index < this.length; index ++) {
        	// 接收回调的返回值用于判断数组该项是否添加进返回数组中
            var temp = callback.call(_that, this[index], index, this);
            // 如果回调返回值为true则向返回数组中push进原数组该属性
            if(temp) newArr.push(this[index]);
        }
        // 将过滤后的新数组返回
        return newArr;
    }

ok那来试验一下:

  var arr = [1, 2, 3];
  var newArr = arr.myFilter(function (item, index, orgin) {
  		console.log(item);	// 1 || 2 || 3
		console.log(index); // 0 || 1 || 2
		console.log(orgin); // Array:[1, 2, 3]
		console.log(this);	// Object: {name: 'myFilter'}
	   	return item > 1; 	
  }, {name: 'myFilter'});
  console.log(newArr); // [2, 3] 大于1的属性

还是那句话我没有测出bug不代表没有bug,欢迎大神拍砖,那有了上面的两个例子下面我就附上map等方法的封装不做详细的解析了:

map:
   Array.prototype.myMap = function (callback, myThis) {
     	var _that = myThis || window, newArr = [];
        for (var index = 0; index < this.length; index ++) {
            var temp = callback.call(_that, this[index], index, this)
            newArr.push(temp)
        }
        return newArr
    }
some & every:
// mySome
 Array.prototype.mySome = function (callback, myThis) {
      var _that = myThis || window, verdict = false;
      for (var index = 0; index < this.length; index++) {
          var temp = callback.call(_that, this[index], index, this)
          if (temp) {
              verdict = true
              break;
          }
      }
      return verdict
  }
  // myEvery
  Array.prototype.myEvery = function (callback, myThis) {
      var _that = myThis || window, verdict = true;
      for (var index = 0; index < this.length; index++) {
          var temp = callback.call(_that, this[index], index, this)
          if (!temp) {
              verdict = false
              break;
          }
      }
      return verdict
  }

欢迎大神拍砖!
ok今天就写到这里,闪人!!!

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
JavaScript中有多种方法可以遍历数组,其中常用的有mapforEachfilter。 1. map方法map方法会对数组中的每个元素调用一个回调函数,并返回一个新的数组,新数组的元素是原始数组中每个元素经过回调函数处理后的结果。例如,我们有一个数组[1, 2, 3],我们可以使用map方法将每个元素乘以2并返回一个新的数组[2, 4, 6]。map方法不会改变原始数组。 2. forEach方法forEach方法会对数组中的每个元素调用一个回调函数,但它不会返回任何内容。通常,forEach方法用于执行一些操作而不需要返回结果,例如打印数组中的每个元素。与map方法不同,forEach方法无法返回修改后的数组。 3. filter方法filter方法会对数组中的每个元素调用一个回调函数,并返回一个新的数组,新数组的元素是回调函数返回值为true的元素。例如,我们有一个数组[1, 2, 3, 4, 5],我们可以使用filter方法筛选出所有大于2的元素并返回一个新的数组[3, 4, 5]。与map方法类似,filter方法也不会改变原始数组。 这三种方法在遍历数组时具有不同的用途。map方法可以用于对数组中的每个元素进行转换或操作,并返回一个新的数组。forEach方法用于执行一些操作而不关心返回值。filter方法用于根据指定的条件筛选出符合条件的元素,并返回一个新的数组。根据具体情况,我们可以选择合适的方法来遍历数组。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值