JavaScript 立即执行函数和闭包

本文详细介绍了JavaScript中的闭包概念,通过示例代码解释了闭包如何形成及工作原理。同时,深入探讨了立即执行函数的特点和两种常见写法,以及其在预编译过程中的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

闭包

function A(){
        function B(){
            console.log("hello world");
        }
        return B;
}
var c = A();
c();//hello world

这就是一个最简单的闭包

翻译为自然语言如下

  • 定义普通函数A
  • 在A中定义普通函数B
  • 在A中返回B
  • 执行A,并把A执行结果赋值给变量C
  • 执行C

当一个内部函数被其外部函数之外的变量引用时,就形成了一个闭包。

立即执行函数

此类函数没有声明,再一次执行过后即释放。适合做初始化工作

//立即执行函数 也会有预编译的过程
var num = (function(a,b,c){
        var d= a+b+c*2-2;
        return d;

}(1,2,3))

立即执行函数的两种写法

  • (function(){}()); W3C 建议第一种
  • (function(){})();

关键点补充:

  • 只有表达式才能被执行符号执行
//此为函数声明,不可以被执行符号执行
function
test(){ var a = 123; }();
  • 能被执行符号执行会忽略函数的名称
//&& || + - ! 会让函数声明变成表达式,加上执行符号 即立即执行函数,然后忽略函数名称
!function test(){

}()
所以立即执行函数可写成
(function(){}());

例题

function test(a,b,c,d){
     console.log(a+b+c+d);
    }(1,2,3,4);

正常不能执行,系统识别成了

function test(a,b,c,d){
     console.log(a+b+c+d);
    }
    
    
    (1,2,3,4);

这样就不会报错,但并不是立即执行函数

转载于:https://www.cnblogs.com/FashionDoo/p/10478770.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值