JavaScript函数this指向
函数的this指向,函数this的确定是在函数执行的时候确认的不是在函数定义的时候确认的
自由变量的查找,是在函数定义的地方查找,向上级作用域查找,不是在执行的地方查找。
第一个打印的this.count是1,第二个是一个坑,第二个打印的是undefined
这个打印结果是4个4
let i
for( i = 0 ; i<=3; i++) {
setTimeout(function() {
console.log(i)
}, 0)
}
setTimeout()里的函数是作为一个普通函数执行,this是window
箭头函数永远取它上一级作用域的this,也就是始终指向箭头函数申明时所在作用域下的this值。本身不会决定this的值
改变函数内this指向
call()、bind()、apply()
1.call
- call的第一个作用是可以调用函数,第二个作用是可以改变函数的this的指向
- call也可以实现继承
2.apply
- 第一个作用也是调用函数,第二个作用也是改变函数的this指向
- 但是他的参数必须是数组形式
- 主要应用是结合Math
f.apply(第一个参数是this,第二个参数是数组)
输出是字符串模式
3.bind
- 不会调用函数,可以改变函数this的指向
- 返回的是原函数改变this指向后的新函数
- 当我们有函数不需要立即调用,但是有需要改变this指向时用bind
4.call、apply、bind的异同点
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· DeepSeek 开源周回顾「GitHub 热点速览」
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了