〖大前端 - 基础入门三大核心之JS篇㉞〗- JavaScript 的「立即执行函数IIFE」

IIFE是JavaScript中的函数表达式,用于创建独立作用域,防止变量污染。它通过将函数转换为表达式立即执行。IIFE常用于封装复杂计算、避免全局变量问题,例如在for循环中创建局部变量以避免闭包问题。文章还提到了作者的背景和相关著作。

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

  • 说明:该文属于 大前端全栈架构白宝书专栏目前阶段免费如需要项目实战或者是体系化资源,文末名片加V!
  • 作者:不渴望力量的哈士奇(哈哥),十余年工作经验, 从事过全栈研发、产品经理等工作,目前在公司担任研发部门CTO。
  • 荣誉:2022年度博客之星Top4、2023年度超级个体得主、谷歌与亚马逊开发者大会特约speaker全栈领域优质创作者



IIFE(Immediately Invoked Function Expression)是 JavaScript 中一种常见的函数表达式,它的特点是定义完毕后立即执行。IIFE 可以用来创建一个独立的作用域,避免变量污染和命名冲突的问题。


⭐ 立即执行函数IIFE

IIFE(Immediately Invoked Function Expression,立即调用函数表达式)是一种特殊的JavaScript函数写法,一但被定义,就立即被调用。

基本语法:

(function () {
    console.log('你好');
})();

IIFE的原理:

IIFE的原理:在JavaScript中规定,语句体式不可以立即执行的,加上圆括号对之后,这个语句体就变成了一个表达式,而表达式是可以立即执行的。

除了加圆括号的方式,也可以通过在函数前面添加一个加号、减号、波浪线等方式将函数变成表达式,达到能够立即执行的目的。只不过圆括号使用的最为广泛。

IIFE的作用:

  • 为变量赋值

  • 当给变量赋值需要一些较为复杂的计算时(如if语句),使用IIFE可以显得语法更加”紧凑“

比如下面的例子:

var age = 19;
var sex = '女';
var title = (function () {
    if (age < 18) {
        return '小朋友';
    } else {
        if (sex == '男') {
            return '先生';
        } else {
            return '女士';
        }
    }
})();
console.log(title);  //
  • IIFE可以在一些场合(如for循环中)将全局变量变为局部变量,语法显得紧凑

先来看一个全局变量导致的问题:

下面的代码中,for循环将函数推入数组中,但由于i是全局变量,导致后面输出的结果都是5

var arr = [];
for (var i = 0; i < 5; i++) {
    arr.push(function () {
        console.log(i);
    })
}
arr[0]();  //5
arr[1]();  //5
arr[2]();  //5
arr[3]();  //5

利用IIFE,我们每次循环时,都立即执行一个函数,通过这个函数,将参数i转换成局部参数。就可以解决这个问题了。

var arr = [];
for (var i = 0; i < 5; i++) {
    (function (i) {   //此时,i就变成了一个局部变量,形成了一个闭包
        arr.push(function () {
            console.log(i);
        })
    })(i);//传入实际参数i
}
arr[0]();  //0
arr[1]();  //1
arr[2]();  //2
arr[3]();  //3

评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

哈哥撩编程

多点...少点...多少给点?

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值