普通函数与箭头函数的this指向的区别

直接上一个简单的下配demo来说明问题
1.使用普通函数
需求:实现点击id为box的盒子,让其变色

  • 方式1—使用普通哈函数

可以发现当你没有在外层保留this的指向时,此时setTimeout定时器中的箭头函数的指向时指向window的,那么此时this.style.background====>window.style.background,因此找不到windowd.style,所以报上面的错误

在这里插入图片描述

当我在外层保留this的指向时,然后我在定时器内函数使用外层保留的this即self,此时打印出的self便指向的时box这个盒子,便可以解决指向问题

在这里插入图片描述

  • 方式2-----使用箭头函数
    在这里插入图片描述

    var box = document.getElementById('box');
    box.addEventListener('click', function () {
      var self = this;
      setTimeout(function () {
        console.log(self)
        self.style.background = "red";


      }, 2000)
    })


    var box = document.getElementById('box');
    box.addEventListener('click', function () {

      setTimeout(() => {
        console.log(this)
        this.style.background = "blue"
      }, 1000)

    })

需求2:对一已经数组。返回数组中的偶数
在这里插入图片描述

 const arr = [2, 5, 8, 7, 9, 12]
    const result = arr.filter(function (item) {
      if (item % 2 === 0) {
        return true
      } else {
        return false
      }
    })
    console.log(result)


    //使用箭头函数
    const result1 = arr.filter((item) => {
      if (item % 2 === 0) {
        return true
      } else {
        return false
      }
    })
    console.log(result1)

    //使用箭头函数
    const result2 = arr.filter(item => item % 2 === 0)
    console.log(result2)

在这里插入图片描述

总结:
1.箭头函数适合于this无关的问题,比如定时器,数组的方法回调
2.箭头函数不适合与this有关的回调,事件回调,对象的方法(如box.addEventListener(‘click’, function () {})—这里的functio就不适合使用箭头函数)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值