#今日说码栏目# 第三十一集 箭头函数的this和普通函数的this区别

本文探讨JavaScript中的箭头函数与普通函数在this指向上的差异。箭头函数的this在定义时即已绑定,通常指向其父级上下文的this,而在forEach等场景中,this始终指向window。相比之下,普通函数的this在运行时绑定,可以被改变,如在对象方法中,this将指向调用该方法的对象。
摘要由CSDN通过智能技术生成

目录

一、箭头函数的this

二、普通函数的this

一、箭头函数的this

①箭头函数的this是定义时绑定的;

②箭头函数不能够改变this指向

③箭头函数本身是没有this,所以它内部的this是继承自执行上下文中的this,一般情况下指向该程序的父级程序,如果没有父级程序,则this指向顶级对象window。

1、forEach()中 函数的this指向,就是window

const test = document.querySelectorAll('li');
  test.forEach(function(item,key){
     console.log(this);  // 输出的是forEach的函数的this指向
     箭头函数的this指向的是是父级程序,forEach()//的this指向的是window。
     item.addEventListener('click' , ()=>{
         console.log(key,this);
     })
 })

二、普通函数的this

①普通函数的this是在执行函数时绑定的; 

②普通函数能够改变this指向;

③普通函数在被某对象调用时,它内部的this会指向调用它的对象;

1、声明式指向--window

 function obj(){
    console.log(this);
}
  obj();</
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值