返回列表 发新帖

avascript立即执行_立即执行作业

[复制链接]

11

主题

23

帖子

23

积分

新手上路

Rank: 1

积分
23
发表于 2024-9-30 11:08:33  | 显示全部楼层 | 阅读模式
JavaScript中的立即执行函数表达式(IIFE)是一种在定义后立即执行的匿名函数。这种特性使其成为创建独立作用域的理想选择,常用于避免全局变量污染和模块化代码。
JavaScript 立即执行函数(IIFE)是一种在定义时立即执行的函数,这种函数通常用于封装变量以防止全局作用域污染,或者创建一个新的私有作用域,以下是一个详细的解释,包括小标题和单元表格:

zbhjb5rgwcae2k1.jpg

zbhjb5rgwcae2k1.jpg


(图片来源网络,侵删)
1、什么是立即执行函数?
立即执行函数(Immediately Invoked Function Expression,简称 IIFE)是一种在定义时立即执行的函数,这种函数可以包含任意数量的语句,但是只有函数体内部的语句会被执行。
2、IIFE 的基本语法
IIFE 的基本语法如下:

(function() {
    // 函数体
})();
3、IIFE 的优点
防止全局作用域污染:IIFE 可以在其内部访问外部作用域的变量,但不会污染全局作用域。
创建新的私有作用域:IIFE 在其内部可以创建新的变量和函数,这些变量和函数只能在 IIFE 内部访问,不能被外部访问。

zbhjcr1qysbk52u.png

zbhjcr1qysbk52u.png


(图片来源网络,侵删)
4、IIFE 的使用场景
模块模式:IIFE 可以用来创建一个模块,这个模块有自己的私有变量和函数,可以被其他代码引用。
避免全局变量冲突:如果有两个脚本使用了相同的全局变量名,那么这两个脚本可能会相互干扰,使用 IIFE 可以避免这种情况。
5、IIFE 的常见模式
模块模式:这是最常见的 IIFE 用法,在这种模式下,IIFE 返回一个对象,这个对象包含了模块的所有公开接口。
单例模式:单例模式是一种设计模式,它保证一个类只有一个实例,并提供一个全局访问点,可以使用 IIFE 来实现单例模式。
6、IIFE 的示例

zbhjegg22bprhnd.jpg

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的使用已经不如以前那么常见了,不过,了解它仍然是有用的,尤其是在阅读旧代码时。
回复

使用道具 举报

发表回复

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表