this关键字在JS中的作用

JS中this就是执行的主体(谁来执行的this就是谁)

如何确定this呢
this这个 keyword确实非常的让人困惑,历史故事让我们觉得其实有一个好方法可以理解.

检查 ‘ . ‘ 左边是谁invoke 这个函数. 例如 xiaoming.age(); age函数里面有this, 然后 ‘. ‘ 旁边是xiaoming , 那么this就是指向xiaoming了.这种叫做 Implicit Binding.

如果点旁边没有,那就检查有没有用到 bind, apply, call 这三种, 有的话就是调用此方法的对象. 这种叫做 explicit binding.

如果上面两个都没有就检查代码里面有没有用到new 这个keyword, 有的话那就是指向new左边的函数对象。 这种叫做new binding

上面三个都没有, 检查是不是有arrow function, 有arrow function的话就是, 那么指向是arrow function的lexical binding 的对象. 就是它的parent. 这种叫做 lexical binding

全部都没有,如果不是strict mode那就是window对象了。如果是strict那就是 error (undefined).

this关键字在JS中的作用

上一篇:Web前端最常用的技能整理,附最新前端学习资料和视频教程


下一篇:vasp