作用域闭包立即执行函数

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')
());

以上是关于作用域闭包立即执行函数的主要内容,如果未能解决你的问题,请参考以下文章

js函数作用域作用域链闭包立即执行函数

闭包和立即执行函数

js函数作用域预编译和作用域链闭包立即执行函数

JavaScript中的匿名函数立即执行函数和闭包

理解JS闭包的含义

JavaScript 闭包 立即执行函数