广告合作
  • 今日头条

    今日头条

  • 百度一下

    百度一下,你就知道

  • 新浪网

    新浪网 - 提供新闻线索,重大新闻爆料

  • 搜狐

    搜狐

  • 豆瓣

    豆瓣

  • 百度贴吧

    百度贴吧——全球领先的中文社区

  • 首页 尚未审核订阅工具 订阅

    javascript 的 "!function" 是什么意思

    来源:网络收集  点击:  时间:2024-02-23
    【导读】:

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

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

    (function(){dosomething...})()

    //或

    (function(){dosomething...}())

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

    这样写会报错:

    function(){alert(1)}()

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

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

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

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

    !function() {return1}()//false

    ~function() {return1}()//-2

    -function() {returnfalse}()//0

    -function() {returnfalse}()//0

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

    扩展资料:

    匿名函数的调用:

    var abc=function(x,y){

    return x+y;

    }

    alert(abc(2,3)); // 5

    上面的操作其实就等于换个方式去定义函数,这种用法是我们比较频繁遇到的。

    例如我们在设定一个DOM元素事件处理函数的时候,我们通常都不会为他们定名字,而是赋予它的对应事件引用一个匿名函数。

    使用()将匿名函数括起来,然后后面再加一对小括号(包含参数列表)。

    alert((new Function(x,y,return x*y;))(2,3));// 6

    参考资料来源:百度百科-JavaScript

    本文关键词:

    版权声明:

    1、本文系转载,版权归原作者所有,旨在传递信息,不代表看本站的观点和立场。

    2、本站仅提供信息发布平台,不承担相关法律责任。

    3、若侵犯您的版权或隐私,请联系本站管理员删除。

    4、文章链接:http://www.1haoku.cn/art_113188.html

    相关资讯

    ©2019-2020 http://www.1haoku.cn/ 国ICP备20009186号05-06 10:11:47  耗时:0.025
    0.0254s