js的作用域
1. 作用域浅层理解
- 作用域一般指一个变量的作用范围
1.1 全局作用域
- 全局作用域在页面打开的时候被创建,页面关闭时被销毁。
- 编写在script标签中的变量和函数,作用域为全局,在页面的任意位置都可以访问到。
- 在全局作用域中有全局对象window,代表一个浏览器窗口,由浏览器创建,可以直接调用。
- 全局作用域中声明的变量和函数会作为window对象的属性和方法保存。
1.2函数作用域
- 调用函数时,函数作用域被创建,函数执行完毕,函数作用域被销毁。
- 每调用一次函数就会创建一个新的函数作用域,他们之间是相互独立的。
- 在函数作用域中可以访问到全局作用域的变量,在函数外无法访问到函数作用域内的变量
- 在函数作用域中访问变量、函数时,会先在自身作用域中寻找,若没有找到,则会到函数的上一级作用域中寻找,一直到全局作用域。
2. 作用域的深层理解
- 执行期的上下文
- 当函数代码执行的前期,会创建一个执行期上下文的内部对象AO(作用域)
- 这个内部的对象是预编译的时候创建出来的,因为当函数被调用的时候会先进行预编译
- 在全局代码执行的前期会创建一个执行期的上下文的对象GO
3.作用域链
会被保存到一个隐式的属性中去[[scope]]这个属性是我们用户访问不到的,但是是存在的,让js引擎来访问的,里面存储的就是作用域链,作用域链是ao和go的集合
<script>
var global
function a() {
function b() {
var bb = 0
aa = 1
}
var aa = 2
b()
}
a()
</script>
a执行则连线,执行完自动断开,在执行再连