关于this的指向问题(总结)

本文总结了JavaScript中this的指向问题,包括全局环境、函数调用、对象方法、事件触发、构造函数以及es6箭头函数的情况。讨论了如何理解和解决this指向问题,如使用that变量缓存、call、apply、bind等方法来改变或确定this的指向。
摘要由CSDN通过智能技术生成

javascript中this的指向一直是前端同事有时会不理解的知识点,也会出现在面试题中,今天我们将来总结下this的指向问题:

注释:
1.全局变量默认挂载在window对象下,一般情况下this指向它的调用者
2.es6的箭头函数中,this指向创建者,并非调用者

举个例子:

一.函数调用时:

非严格模式:默认挂载在window对象下,this指向它的调用者即window,所以输出window对象

const func = function () {
   
    console.log(this);
    const func2 = function () {
   
      console.log(this);
    };
    func2(); //Window
  };
  func(); //Window

严格模式:this不允许指向全局变量window,所以输出为undefined(func2在函数直接调用时默认指向了全局window

'use strict'
  const func = function () {
   
    console.log(this);
    const func2 = function () {
   
      console.log(this);
    };
    func2(); //undefined
  };
  func(); //undefined

**

解决方法:正确的设计方式是内部函数的this 应该绑定到其外层函数对应的对象上,为了规避这种缺陷,js出了变量替代的方法

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值