热点面试题:聊聊对 this 的理解?

前言
欢迎关注 『前端进阶圈』 公众号 ,一起探索学习前端技术......
前端小菜鸡一枚,分享的文章纯属个人见解,若有不正确或可待讨论点可随意评论,与各位同学一起学习~
聊聊对 this 对象的理解?
定义
在执行上下文中的一个属性,它指向最后一次调用这个属性或方法的对象。通常有四种情况来判断。
四种情况如下
1. 函数调用模式:当一个函数不是一个对象的属性时,直接作为函数来调用时, 严格模式下指向 undefined, 非严格模式下,this 指向全局对象。
2. 方法调用模式:如果一个函数作为一个对象的方法来调用时,this 指向当前这个对象
3. 构造器调用模式:如果一个函数通过 new 调用时,函数执行前会新创建一个对象,this 指向这个新创建的对象。
4. apply, call, bind 模式:显式更改 this 指向,严格模式下,指向绑定的第一个参数,非严格模式下,null 和 undefined 指向全局对象(浏览器中是 window),其余指向被 new Object() 包裹的对象。
aplly: apply(this绑定的对象,参数数组)func.apply(thisValue, [arg1, arg2, ...])
call: call(this绑定的对象,一个个参数)func.call(thisValue, arg1, arg2, ...)
bind: bind(this绑定的对象)func.bind(thisValue)
箭头函数规则
不会使用以上原则,而是根据当前作用域来决定
this, 也就是说箭头函数会继承外层函数,调用的this绑定,没有外层函数,则是指向全局(浏览器中是window)。
this 优先级
构造器模式 > apply, call, bind > 方法调用模式 > 函数调用模式
文章特殊字符描述:
问题标注
Q:(question)答案标注
R:(result)注意事项标准:
A:(attention matters)详情描述标注:
D:(detail info)总结标注:
S:(summary)分析标注:
Ana:(analysis)提示标注:
T:(tips)
往期回顾:
最后:
版权声明: 本文为 InfoQ 作者【控心つcrazy】的原创文章。
原文链接:【http://xie.infoq.cn/article/781ab692fc9b31000f865686c】。文章转载请联系作者。










评论