当前位置: 首页 > news >正文

没想到的 IIFE

没想到的 IIFE

有时候我们想要立即执行一下所定义的函数,可以怎么做呢?

function foo(num) {return num ?? 1;
}foo();

写完然后调用对吧,这是可以的,但你有没有觉得这其实有点脱裤子放屁了,完全可以直接调用就是了对吧,也就是 IIFE(Immediately-Invoked Function Expression),立即执行函数表达式

(function foo() {return num ?? 1;
})()

有人说, IIFE 很简单呀,还需要你写文章吗?如果我是要写怎么使用 IIFE,当然没必要,我写这个,是因为我发现了一点有趣的东西。

什么呢?我们先来看三段语句:

function foo() {return num ?? 1;
}()
function foo(num) {return num ?? 1;
}(2)
(function foo(num) {return num ?? 1;
}());

你觉得上面这些能执行成功吗?

不是想考哈,考这个太没意思了,主要就是探究一下

是不是不知道了哇,先不要慌,我们从头看:

function foo(num) {return num ?? 1;
}foo();

从这里是不是可以看出,只要在函数名后面加上圆括号,就能调用(执行)函数了。那么我们可以大胆的猜测,直接在函数后面添加括号是不是也可以执行呢?

我们来看看呢?

function foo(num) {return num ?? 1;
}();	
// SyntaxError: Unexpected token ')'

执行直接会报语法错误,为什么呢?因为:

  1. function foo(num) {...} 是一段语句(函数声明语句)
  2. 放在语句后的括号与前面的语句完全分开,只是一个分组运算符(用作控制计算优先级的手段),此时的括号里面需要包含一个表达式。

那么,下面这段代码的结果就不言而喻了

function foo(num) {return num ?? 1;
}(2)

既不会报错,也不会执行 foo,因为 (2) 和前面的语句是完全分开的。

那再来看第三段:

(function foo(num) {return num ?? 1;
}());

这就能正常执行了,为什么呢?

因为:

  1. 括号里面的内容都会识别为表达式
  2. 放在表达式后的括号表明该表达式是要调用的函数

当然,下面这种也是能正常工作的,左侧括号使一个表达式。

(function foo(num) {return num ?? 1;
})();

我想,看到这里,你应该知道为啥在文章开头我要将 “立即执行函数表达式” 中的函数表达式标红了吧,这里也纠正一个常犯的错误:IIFE 可不是一个函数,而是一个表达式哟!

http://www.lryc.cn/news/22512.html

相关文章:

  • 「牛客网C」初学者入门训练BC156
  • 【Proteus仿真】【STM32单片机】粮仓温湿度控制系统设计
  • 九年时间,倾情投入,JumpServer开源堡垒机v3.0正式发布
  • 【ROS学习笔记5】服务通信
  • “华为杯”研究生数学建模竞赛2006年-【华为杯】A题:Ad Hoc 网络中的区域划分和资源分配问题(附获奖论文)
  • 编写第一个JAVA程序,常见踩坑记录
  • 求职陷阱:Lazarus组织以日本瑞穗銀行等招聘信息为诱饵的攻击活动分析
  • 【C语言每日一题】判断字符串旋转结果(附加字符串左旋详解)
  • SpringSecurity+JWT+Redis进行用户鉴权和接口权限的控制
  • 七大排序(Java)
  • 分享一些可以快速掌握python语法的小技巧
  • 1.FFmpeg-音视频基础
  • Parasoft的自动化测试平台到底强在哪?
  • FastDDS-0.简介
  • Flutter入门进阶之旅 -开源Flutter项目
  • Opencv项目实战:21 美国ASL手势识别
  • 强化学习RL 01: Reinforcement Learning 基础
  • C语言之练习题合集
  • sublimeText3新建文件自动添加注释头
  • AndroidStudio打包HBuilderX的H5+项目为安卓App【一次过,无任何异常报错】
  • 【Linux】进程概念
  • 使用pyinstaller库打包exe时显示KeyError怎么办
  • k8s新增节点机器,无法拉取和推送镜像的解决方案
  • 测试报告踩坑的点
  • 【Java】创建多线程的四种方式
  • 【数据结构】队列的接口实现(附图解和源码)
  • 日本知名动画公司东映动画加入 The Sandbox 元宇宙
  • QuickHMI Hawk R3 Crack
  • 【C语言】寻找隐藏字母游戏
  • 【C++】list 相关接口的模拟实现