本文摘自PHP中文网,作者coldplay.xixi,侵删。
立即调用函数目录
- 一、了解立即调用函数表达式
- 二、立即调用函数表达式报错了?
- 三、使用立即调用函数的正确姿势
- 四、常见使用场景
写在最后
(免费学习推荐:javascript视频教程)
一、了解立即调用函数表达式
1.1 思维导图
1.2 什么是立即调用?
在详细了解这个之前,我们来谈了解一下“自执行”这个叫法,本文对这个功能的叫法也不一定完全对,每个人对他的理解都不一样,我们在这里用立即调用
~
立即调用:
- 顾名思义,该表达式一被
创建就立即执行
。 - 是一个在定义时就会立即执行的
JavaScript 函数
。
1 2 |
|
这是一个被称为 自执行匿名函数
的设计模式,主要包含两部分:
- 第一部分是包围在 圆括号运算符
()
里的一个匿名函数,这个匿名函数拥有独立的词法作用域。这不仅避免了外界访问此 IIFE 中的变量,而且又不会污染全局作用域。 - 第二部分再一次使用
()
创建了一个立即执行函数表达式,JavaScript 引擎到此将直接执行函数。
1.3 核心问题
当你声明一个函数的时候,通过在后面加括号就可以实现立即执行吗?
1 2 3 4 5 |
|
很显然,例子中的第二条和第三条确实报错了,而且报错内容不一样,那么问题出现在哪呢?
二、立即调用函数表达式报错了?
有时,我们定义函数之后,立即调用该函数,这时不能在函数的定义后面直接加圆括号,这会产生语法错误。产生语法错误的原因是,function
这个关键字,既可以当做语句,也可以当做表达式,比如下边:
1 |
|
为了避免解析上的歧义,JS引擎规定,如果function出现在行首,一律解析成语句。因此JS引擎看到行首是function关键字以后,认为这一段都是函数定义,不应该以括号结尾
,在它看来括号
只是分组操作符。
1 2 3 4 5 |
|
三、使用立即调用函数的正确姿势
要解决上述问题,非常简单。
我们只需要用大括弧
将代码的代码全部括住就行了,因为JavaScript里括弧()
里面不能包含语句,所以在这一点上,解析器在解析function关键字的时候,会将相应的代码解析成function表达式,而不是function声明。
3.1 常见使用姿势
1 |
|
3.2 不常见的使用姿势(一)
1 2 3 |
|
3.3 不常见的使用姿势(二)
1 2 3 4 |
|
3.4 不常见的使用姿势(三)
还有一个情况,使用new和void关键字,不过不太常见罢了。
1 2 3 |
|
四、常见使用场景
4.1 隔离作用域
IIFE最常见的功能,就是隔离作用域,在ES6之前JS原生也没有块级作用域的概念,所以需要函数作用域来模拟。
举例:
1 2 3 4 5 6 7 8 |
|
你仍然可以在其他地方声明同名变量~
4.2 惰性函数
DOM事件添加中,为了兼容现代浏览器和IE浏览器,我们需要对浏览器环境进行一次判断:
1 2 3 4 5 6 7 8 9 10 11 |
|
4.3 用闭包保存状态
这里我仅举个例子,为我的下一篇文章――《JavaScript中的闭包》卖个关子
1 2 3 4 5 6 7 |
|
注意
当函数变成立即执行的函数表达式时,表达式中的变量不能从外部访问。
1 2 |
|
将 IIFE 分配给一个变量,不是存储 IIFE 本身,而是存储 IIFE 执行后返回的结果。
1 2 3 |
|
相关免费学习推荐:javascript(视频)
以上就是深入理解JavaScript立即调用函数表达式(IIFE)的详细内容,更多文章请关注木庄网络博客!
相关阅读 >>
javascript介绍service worker 的生命周期及使用场景
更多相关阅读请进入《javascript》频道 >>

Vue.js 设计与实现 基于Vue.js 3 深入解析Vue.js 设计细节
本书对 Vue.js 3 技术细节的分析非常可靠,对于需要深入理解 Vue.js 3 的用户会有很大的帮助。——尤雨溪,Vue.js作者