js中的this简单总结

js中的this简单总结

JavaScript 中 this 不是固定不变的,它会随着执行环境的改变而改变。

this的指向问题

在非严格模式下

  1. 单独使用this的话,那么this指向window对象。代码块中的this指向的是window对象。
  2. 如果this在函数中有以下三种情况。第一种就是普通函数中的this,它指向的是仍然是window对象。第二种就是在构造函数中,如果使用new对其进行实例化,那么new这个关键自会改变this的指向,此时的this指向的是Object。第三种就是箭头函数中的this,箭头函数不会创建自己的this,它只会从自己的作用域链的上一层继承this。
  3. 如果this在对象(DOM对象,自定义对象,BOM对象,事件对象)中。那么这个this指向的就是本对象。对象的call()与apply()方法原理就是改变this的指向。

在严格模式下

  1. 函数中的this未定义。严格模式下函数是没有绑定到 this 上,这时候 this 是 undefined。
  2. 单独使用的话this指向window对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值