JavaScript学习手册(55)
Posted designbyly
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript学习手册(55)相关的知识,希望对你有一定的参考价值。
变量提升与函数提升
-
变量提升声明
通过var定义(声明)的变量,在定义语句之前就可以访问到
值:undefined
-
函数提升声明
通过function声明的函数,在之前就可以调用
值:函数定义(对象)
-
问题:变量提升和函数提升是如何产生的?
执行上下文
代码分类(位置)
- 全局代码
- 函数代码
全局执行上下文
-
在执行全局代码前将window确定为全局执行上下文
-
对全局数据进行预处理
var定义的全局变量==》undefined,添加为window的属性
function声明的全局函数==》赋值(fun),添加为window的方法
this==》赋值(window)
-
开始执行全局代码
函数执行上下文
-
在调用函数,准备执行函数体之前,创建对应的函数执行上下文对象(虚拟的,存在于栈中)
-
对全局数据进行预处理
形参变量==》赋值(实参)==》添加为执行上下文的属性
arguments==》赋值(实参列表),添加为执行上下文的属性
var定义的局部变量==》undefined,添加为执行上下文的方法
function声明的函数==》赋值(fun),添加为执行上下文的方法
this==》赋值(调用函数的对象)
-
开始执行函数体代码
执行上下文栈
- 在全局代码执行前,JS引擎就会创建一个栈来存储管理所有的执行上下文对象
- 在全局执行上下文(window)确定后,将其添加到栈中(压栈)
- 在函数执行上下文创建后,将其添加到栈中(压栈)
- 在当前函数执行完后,将栈顶的对象移除(出栈)
- 当所有的代码执行完后,栈中只剩下window
每日一句
这世界的大多数事情,不是稍微努力就可以搞定
以上是关于JavaScript学习手册(55)的主要内容,如果未能解决你的问题,请参考以下文章