1.this的指向在函数定义时确定不了的,只有函数执行时才能确定this到底指向谁,实际上this的最终指向的事调用它的对象。
2.分为以下情况:
(1)this没有被上一级调用,this指向的是window.
(2)this有被上一级调用,this指向的是上一级对象。
(3)函数中包含多个对象,尽管这个函数是被最外层的对象所调用,this指向的是也只是它上一层对象。
一句话:
指向直接调用它的对象,且永远指向的是是最后调用它的对象。即看执行时是谁调用的。
3.箭头函数的this:
总是指向函数定义时,this来自函数作用域链。
4.执行环境:
所有变量都存在于一个执行环境中,这个执行环境决定了变量的生命周期。
包括:
全局执行环境、函数执行环境。
5.作用域链:
执行流每进入一个执行环境,都会创建一个作用域链,由执行环境的变量对象组成。
作用域链前端是当前执行环境的变量对象–下一个。。。。全局window。
6.执行上下文:
js代码执行时所在环境的抽象概念。
生命周期:创建阶段—>执行阶—>回收阶段。
创建:
(1)创建变量对象。
(2)创建作用域。
(3)确定this指向。
执行:
给变量赋值。
回收:
执行上下文出栈等待虚拟机回收执行上下文。
7.活动对象:
变量对象中的属性都不能访问,但进入了执行阶段后,变成了活动对象。
可参考:https://www.cnblogs.com/fundebug/p/understand-javascript-context-and-stack.html
https://www.cnblogs.com/pssp/p/5216085.html