zoukankan      html  css  js  c++  java
  • JS中!function(){}()的理解

    这种写法,是一种立即执行函数的写法,即IIFE等设计模式。这种函数在函数定义的地方就直接执行了。

    理解IIFE设计模式的关键是要认识到,在ES6之前,JavaScript仅具有函数作用域(因此缺少块作用域),并通过闭包内部的引用传递。ES6之后情况已不再如此,因为JavaScript的ES6版本使用letconst关键字实现了块作用域。

     (function(){})()是匿名函数,主要利用函数内的变量作用域,避免产生全局变量,影响整体页面环境,增加代码的兼容性。

    (function(){})是一个标准的函数定义,但是没有赋值给任何变量。所以是没有名字的函数,叫匿名函数。没有名字就无法像普通函数那样随时随地调用了,所以在他定义完成后就马上调用他,后面的括号()是运行这个函数的意思。


    如下几种写法作用是相同的:

    !function () { /* ... */ }();
    ~function () { /* ... */ }();
    -function () { /* ... */ }();
    +function () { /* ... */ }();
    void function () { /* ... */ }();
    (function (){/*...*/}());
    (function (){/*...*/})();

    所以:!function(){}()写法和(function(){})()是相同的

    !function(){}()

    ①函数后的();表示要执行这个函数;

    ②而();要求前面必须是一个表达式。(最后有js表达式的定义)。

    ③所以“!”的作用是将function(){}函数体转为一个函数表达式。

  • 相关阅读:
    Swift8-枚举Enumerations
    Swift7-闭包
    Swift6-函数
    Swift5-控制流
    Swift4-集合类型
    什么是node.js
    nodejs的安装
    环境变量的认识,,,
    shell是什么,各种shell的初步认识,适用于初学者
    exports和module.exports的区别
  • 原文地址:https://www.cnblogs.com/yangxianyang/p/13675566.html
Copyright © 2011-2022 走看看