匿名函数以及为什么要在匿名函数前面加“!”或者“;”

时间:2022-11-03 19:14:22

这几天经常遇见这样的写法:

;(function () {}) () 

开始的时候以为是书写错误,多加了个分号,后来遇到的多了,才意识到可能是我错了...

然后就上网查了一番,现在终于大白于天下,整理记录一下吧~

首先要知道什么是匿名函数,我们知道函数的声明方式有以下两种:

function fn() {} // 声明式

var fn = function(){} // 赋值表达式

然后调用这个函数的时候就在函数名后面加一对小括号:

fn ()

但是,当我们直接在声明的函数后面直接加()时,浏览器会报错:

function(){}() // 浏览器无法解析

但是如果将函数体用()包起来,是不会报错的,像下面这样:

(function(){})() // 这个也就是匿名函数

原因是,使用括号包裹函数体,浏览器会以函数表达式的方式调用定义函数,也就是任何能将函数变成一个函数表达式的方法,都可以被浏览器正确接续,有这个功能的符号比如:! + - || 等一元操作符

!function(){}() // 这样是可以滴

那前面加;的是神马意思呢?

“;”一般在js中是为了分隔代码,js可以使用换行分隔代码,但是当js文件压缩后换行符一般会被删掉,就会把代码连在一起,可能会出错,所以前面加上;就保险了。。。

好吧,说了这么多,其实“;”就是起到AQT的作用 。。。