为了账号安全,请及时绑定邮箱和手机立即绑定

javascript 的 "!function" 是什么意思?

javascript 的 "!function" 是什么意思?

三国纷争 2019-02-11 12:12:20
javascript 的 "!function" 是什么意思?
查看完整描述

1 回答

?
四季花海

TA贡献1811条经验 获得超5个赞

!function跟(function(){... })();函数意义相同,叫做立即运行的匿名函数(也叫立即调用函数)。

js中可以这样创建一个匿名函数

(function(){do something...})()

//或

(function(){do something...}())

匿名函数后面的小括号()是为了让匿名函数立即执行,其实就是一个函数调用。

这样写会报错:

function(){alert(1)}()

因为function前面没有(或者! ~之类的运算符,js解析器会试图将关键字function解析成函数声明语句,而不是函数定义表达式。

作为组运算符,小括号()会将其内部的表达式当成一个整体,然后返回结果,所以定义一个匿名函数正确的格式就是用小括号将函数体括起来。

同样的! ~ + -等运算符也有同样的效果,这是因为匿名函数也是一种值,这些运算符会将后面的函数体当成一个整体,先对匿名函数进行求值,然后在对结果进行运算。

不过这些运算符虽然能够达到让匿名函数立即执行的目的,但是要小心他们是有副作用的,比如:

!function() {return 1}()//false

~function() {return 1}()//-2

-function() {return false}()//0

-function() {return false}()//0

没错,他们会对函数的返回值进行运算,这样可能会导致最终的结果和你想要的结果不一样。当然,对于那些没有返回值的函数来说,当然是没有什么影响了。



查看完整回答
反对 回复 2019-02-15
  • 1 回答
  • 0 关注
  • 443 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号