当前位置:网站首页>#yyds干货盘点#重新梳理箭头函数的this
#yyds干货盘点#重新梳理箭头函数的this
2022-07-06 12:39:00 【51CTO】
记得之前分享过this的用法,是关于普通函数、构造函数的this,今天主要分享ES6箭头函数的this。先看普通函数下的this。
普通函数下的this:
- 在普通函数中的this总是代表它的直接调用者,在默认情况下,this指的是window,
- 在严格模式下,没有直接调用者的函数中的this是 undefined使用
- call,apply,bind(ES5新增)绑定的,this指的是 绑定的对象
箭头函数中的this:
- 箭头函数没有自己的this, 它的this是继承而来; 默认指向在定义它时所处的对象(宿主对象),
- 而不是执行时的对象, 定义它的时候,可能环境是window,也有可能是其他的。
普通函数
test是一个全局函数,也就是挂载在window对象下的 test()等价于window.test();
func的宿主环境是obj,所以func里面的this是obj。 定时器中的函数,由于没有默认的宿主对象,所以this指向window 严格模式下的this:
严格模式
在严格模式下,没有直接调用者的函数中的this是 undefined
有直接调用者的this是它的调用者
箭头函数
此时的 this继承自obj, 指的是定义它的对象obj, 而不是 window
因为f1定义时所处的函数 中的 this是指的 obj, setTimeout中的箭头函数this继承自f1,所以不管有多层嵌套,都是 obj
箭头函数没有this的绑定,必须通过查找作用链来决定其值。如果箭头函数被非箭头函数包含,则this绑定的是最近以层的非箭头函数的this;否则。this的值会被设置为undefined。 箭头函数在定义的时候它所处的环境相当于是window, 所以在箭头函数内部的this函数window。
边栏推荐
- How to upgrade high value-added links in the textile and clothing industry? APS to help
- 解剖生理学复习题·VIII血液系统
- Learn to punch in Web
- [DIY]如何制作一款个性的收音机
- [DIY]如何制作一款個性的收音機
- [cloud lesson] EI lesson 47 Mrs offline data analysis - processing OBS data through Flink
- 01 基础入门-概念名词
- Unity load AB package
- How to select several hard coded SQL rows- How to select several hardcoded SQL rows?
- Case ① | host security construction: best practice of 3 levels and 11 capabilities
猜你喜欢
为什么新手在编程社区提问经常得不到回答,甚至还会被嘲讽?
使用.Net驱动Jetson Nano的OLED显示屏
Mécanisme de fonctionnement et de mise à jour de [Widget Wechat]
Force deduction brush question - 98 Validate binary search tree
Web security - payload
Spark SQL chasing Wife Series (initial understanding)
Tencent byte and other big companies interview real questions summary, Netease architects in-depth explanation of Android Development
【每周一坑】正整数分解质因数 +【解答】计算100以内质数之和
"Penalty kick" games
Continuous test (CT) practical experience sharing
随机推荐
Logic is a good thing
【微信小程序】运行机制和更新机制
2022 Guangdong Provincial Safety Officer C certificate third batch (full-time safety production management personnel) simulation examination and Guangdong Provincial Safety Officer C certificate third
[DIY]如何制作一款個性的收音機
use. Net drives the OLED display of Jetson nano
8086指令码汇总表(表格)
[network planning] Chapter 3 data link layer (3) channel division medium access control
C language games - minesweeping
Rhcsa Road
Rhcsa Road
Detailed introduction of distributed pressure measurement system VIII: basic introduction of akka actor model
Error analysis ~csdn rebound shell error
JS get browser system language
Introduction of Xia Zhigang
Digital triangle model acwing 1018 Minimum toll
02 基础入门-数据包拓展
Tencent byte Alibaba Xiaomi jd.com offer got a soft hand, and the teacher said it was great
Value of APS application in food industry
Extraction rules and test objectives of performance test points
Distributed ID