书法字典:https://www.shufadict.com

javascript定义函数后立即执行(IIFE)

Talk is cheap, show me the code.

复制代码
// Immediately Invoked Function Expression - IIFE
// 定义后立即执行的JavaScript函数。

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

// 无参数的情况
(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,这种写法在实际应用中不常见。
!(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文件出错,有时候要在函数前面加分号,表示前面语句结束,这是一个新的开始。详见https://www.cnblogs.com/daysme/p/6440012.html
// 为什么要合并js文件呢?很多打包工具如webpack为了减少bundle体积,都会合并js文件,形成一个大的chunk.js,大家都不陌生吧。
;(function () {
  console.log("I am a new start");
})();
复制代码

== The End ==

posted on   翰墨小生  阅读(816)  评论(0编辑  收藏  举报

编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 单线程的Redis速度为什么快?
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 展开说说关于C#中ORM框架的用法!
· SQL Server 2025 AI相关能力初探
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
历史上的今天:
2015-08-08 onCreateView中加载大位图
2012-08-08 几何变换详解

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
书法字典:https://www.shufadict.com
点击右上角即可分享
微信分享提示