|
JavaScript中的立即执行函数表达式(IIFE)是一种在定义后立即执行的匿名函数。这种特性使其成为创建独立作用域的理想选择,常用于避免全局变量污染和模块化代码。
JavaScript 立即执行函数(IIFE)是一种在定义时立即执行的函数,这种函数通常用于封装变量以防止全局作用域污染,或者创建一个新的私有作用域,以下是一个详细的解释,包括小标题和单元表格:
zbhjb5rgwcae2k1.jpg
(图片来源网络,侵删)
1、什么是立即执行函数?
立即执行函数(Immediately Invoked Function Expression,简称 IIFE)是一种在定义时立即执行的函数,这种函数可以包含任意数量的语句,但是只有函数体内部的语句会被执行。
2、IIFE 的基本语法
IIFE 的基本语法如下:
(function() {
// 函数体
})();
3、IIFE 的优点
防止全局作用域污染:IIFE 可以在其内部访问外部作用域的变量,但不会污染全局作用域。
创建新的私有作用域:IIFE 在其内部可以创建新的变量和函数,这些变量和函数只能在 IIFE 内部访问,不能被外部访问。
zbhjcr1qysbk52u.png
(图片来源网络,侵删)
4、IIFE 的使用场景
模块模式:IIFE 可以用来创建一个模块,这个模块有自己的私有变量和函数,可以被其他代码引用。
避免全局变量冲突:如果有两个脚本使用了相同的全局变量名,那么这两个脚本可能会相互干扰,使用 IIFE 可以避免这种情况。
5、IIFE 的常见模式
模块模式:这是最常见的 IIFE 用法,在这种模式下,IIFE 返回一个对象,这个对象包含了模块的所有公开接口。
单例模式:单例模式是一种设计模式,它保证一个类只有一个实例,并提供一个全局访问点,可以使用 IIFE 来实现单例模式。
6、IIFE 的示例
zbhjegg22bprhnd.jpg
(图片来源网络,侵删)
以下是一个简单的 IIFE 示例:
(function() {
var message = "Hello, world!";
console.log(message); // 输出 "Hello, world!"
})();
在这个示例中,message 变量是 IIFE 的私有变量,只能在 IIFE 内部访问。
下面是一个简单的介绍,展示了JavaScript中立即执行函数(Immediately Invoked Function Expression,简称IIFE)的基本概念和示例。
术语 | 描述 | 语法 | 示例 | IIFE | 立即执行函数表达式,意味着在定义后立即执行 | (function() {...})(); 或(function() {...}()); | (function() { console.log('Hello, world!'); }()); | 参数 | IIFE可以接受参数 | (function(a, b) { console.log(a + b); })(1, 2); | (function(a, b) { console.log(a + b); }(1, 2)); | 命名 | IIFE内部的函数可以命名,也可以匿名 | (function namedFunction(a, b) { console.log(a + b); })(1, 2); | | 作用域 | IIFE创建了一个新的作用域,避免全局命名空间的污染 | (function() { var localVar = 'I am local'; }()); console.log(localVar); // 抛出错误,因为localVar在IIFE内部 | | 立即执行 | 可以在代码的任何地方立即执行,通常用于初始化 | // 在代码开始时立即执行 var result = (function() { var x = 10; return x * x; }()); console.log(result); // 100 | |
请注意,在现代JavaScript中,由于let和const的出现,以及模块化编程的普及,IIFE的使用已经不如以前那么常见了,不过,了解它仍然是有用的,尤其是在阅读旧代码时。 |
|