作用域闭包立即执行函数
Posted 一杯清泉
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了作用域闭包立即执行函数相关的知识,希望对你有一定的参考价值。
一、作用域(Scope)
[[scope]]指的就是我们所说的作用域,其中存储了运行期上下文的集合。即作用域决定了代码区块中变量和其他资源的可见性。
1、全局作用域
在外面定义的函数、变量,没有定义,却直接赋值的变量也属于全局变量,即拥有全局作用域。此外,window的属性也拥有全局作用域。
<script type="text/javascript">
function test();
const a = 0;
</script>
如上,函数test,变量 a 就是全局作用域,在全局生效,不会被销毁,除非程序结束。
2、局部作用域
在函数内部定义的函数、变量等,被叫做局部作用域,局部作用域的数据的生命周期在该函数执行完以后就被释放。
function test()
function a()
const b = 0;
;
如上,函数test是全局作用域,函数内部的 a,b 则是局部作用域,当在外界调用时候内部时候,a 或者 b 执行结束直接被释放掉。
3、函数执行的上下文
当函数执行时,会创建一个称为执行期上下文的内部对象。一个执行期上下文定义了一个函数执行时的环境,函数每次执行时对应的执行上下文都是独一无二的,所以多次调用一个函数会导致创建多个执行上下文,当函数执行完毕,执行上下文被销毁。
二、闭包
函数内部的变量(局部变量)转化为全局变量,即:定义在一个函数内部的函数,如下:
function test()
function a()
console.log('a')
function b()
console.log('b')
return [a,b]
;
test()[0]();
闭包可以将函数内部的变量(局部变量)转化为全局变量。
三、立即执行函数
运行 js 环境,函数立马被执行。
1、方法1
(function test()
console.log('执行了1')
)();
2、方法2
(function test()
console.log('执行了2')
());
以上是关于作用域闭包立即执行函数的主要内容,如果未能解决你的问题,请参考以下文章