定义后立即执行的JavaScript函数 - Immediately Invoked Function Expression - IIFE

// 基本语法,将函数定义在()内部,最后附加()执行函数。
// 一个小技巧,先写下两个(), 然后第一个()内添加函数定义,第二个()添加调用参数。

// 无参数的情况

(function () {
  console.log("I am running immediately after define");
})();


// 有参数的情况

(function(a, b) {
  console.log(a + " + " + b + " = " + (a + b));
})(1, 2);


// 使用箭头函数,无参

(() => {
  console.log("IIFE with arrow function")
})();

// 使用箭头函数,有参。(如果箭头函数体内只有一行代码,那么return和{}可以省略)

((a, b) => console.log(a + b))(1, 2);


// 变种写法,第二个()也可以写在第一个()内部结尾处,但是这种写法不支持箭头函数哦。

(function () {
  console.log("another way...")
}());

// 使用一元运算符也可以创建IIFE,这种写法在实际应用中不常见。

// 但是诸多JS框架中大量使用了这种写法,用我们师父的说法:是不是感觉很拽?

!function() {
  console.log("IIFE with !")
}();

~function() {
  console.log("IIFE with ~")
}();

+function() {
  console.log("IIFE with +")
}();

-function() {
  console.log("IIFE with -")
}();

// IIFE也可以为函数取名字,但是这个名字没啥用,因为你不能使用该名字调用该函数。

(function test() {
  console.log("IIFE with name...");
})();

// 为了防止合并javascript文件出错,有时候要在函数前面加分号,表示前面语句结束,这是一个新的开始.
// 为什么要合并js文件呢?很多打包工具如webpack为了减少bundle体积,都会合并js文件,形成一个大的chunk.js。

;(function () {
  console.log("I am a new start");
})();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值