JavaScript立即执行函数的三种不同写法

当我们想要立即调用一个函数时,就需要用到JavaScript立即执行函数。立即执行函数是一个函数执行完毕后立即被调用执行,而不是等到再次调用。它常用于模块化开发,而这个函数中的变量不会污染全局变量。

下面来讲解三种不同写法:

写法一:使用圆括号把函数括起来

(function() {
  // 函数体
})();

这是最常见的一种写法,把函数用圆括号括起来,这个圆括号是把函数表达式变成了函数调用表达式,然后再使用另外一个圆括号把整个表达式括起来进行调用。

这种写法也是非常常用的模式,圆括号会让浏览器把表达式解析完毕之后再去执行。这样会避免一些因误解产生的错误。

示例:

(function () {
  var name = "Jack";
  console.log(name); // "Jack"
})();
console.log(name); // ReferenceError: name is not defined

在上面的例子中,我们创建了一个立即执行函数并给它命名,然后立即调用它。该函数中的变量name只能在该函数中使用,不能在外部访问。

写法二:使用函数表达式

函数表达式的写法与写法一很相似,只是不加圆括号直接使用函数表达式代替函数进行调用。

let func = function() {
  // 函数体
}();

示例:

let func = function () {
  var name = "Jack";
  console.log(name);
}();
console.log(name); // ReferenceError: name is not defined

可以看到,这两种写法实现效果一样,只是使用方式不同,可以按个人喜好进行选择。

写法三:使用自执行函数

使用自执行函数需要首先定义一个匿名函数,然后在声明后面紧跟两个圆括号(),最后加上一个括号把整个表达式括起来调用。

!function(){
  // 函数体
}();

示例:

!function () {
  var name = "Jack";
  console.log(name);
}();
console.log(name); // ReferenceError: name is not defined

在上面的代码中,我们使用了一个自执行函数,这个函数中的变量name只能在该函数中使用,外部不能访问。自执行函数的这种写法常用于前端开发中的代码压缩与混淆。

综上所述,以上三种立即执行函数的写法都是可以实现同样的效果,写法一和写法二较为常用,而写法三适用于一些特殊场景。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:JavaScript立即执行函数的三种不同写法 - Python技术站

(0)
上一篇 2023年5月27日
下一篇 2023年5月27日

相关文章

  • javaScript中push函数用法实例分析

    JavaScript中的push函数用于在数组末尾添加一个或多个元素,并返回新数组的长度。在本篇攻略中,我们将分析push函数的用法和几个示例来更好地理解其用法。 1. push函数基本用法 push函数是JavaScript中数组对象的一种方法,语法格式如下: arr.push(element1[, …[, elementN]]) 其中arr是要进行添…

    JavaScript 2023年5月27日
    00
  • jQuery插件slicebox实现3D动画图片轮播切换特效

    针对“jQuery插件slicebox实现3D动画图片轮播切换特效”的攻略,我们可以按照以下步骤来进行: 一、引入slicebox插件 在实现3D动画图片轮播切换特效前,首先需要引入slicebox插件及其相关资源文件。可以通过在HTML中引入以下内容来实现: <link rel="stylesheet" href="pa…

    JavaScript 2023年6月11日
    00
  • JavaScript实现使用Canvas绘制图形的基本教程

    JavaScript实现使用Canvas绘制图形是前端开发中的重要技能之一。下面是使用Canvas绘制图形的基本教程。 1. 了解Canvas Canvas是HTML5中提供的一个可以在网页中使用JavaScript绘制图形的元素,它可以用来绘制各种图形,如直线、矩形、圆形、多边形以及文本等。 2. HTML中创建Canvas元素 在HTML中,可以使用&l…

    JavaScript 2023年5月28日
    00
  • JS正则表达式验证数字代码

    下面我将详细讲解 JS 正则表达式验证数字代码的完整攻略。 步骤 1. 构建正则表达式 首先需要构建一个用于验证数字的正则表达式。一般来说,数字可以包含整数和小数,还可能有正负号。 验证整数和小数的正则表达式如下: /^-?\d+(\.\d+)?$/ 其中: ^ 表示字符串开始 -? 表示可以有一个可选的负号 \d+ 表示至少一个数字 (\.\d+)? 表示…

    JavaScript 2023年6月10日
    00
  • javascript实现的字符串与十六进制表示字符串相互转换方法

    当我们需要将一个字符串转换为十六进制格式时,可以使用 JavaScript 中的 toString(16) 方法来实现。而将十六进制格式的字符串转换为正常的字符串时,则需要先将其转换为十进制数,再调用字符编码方法 String.fromCharCode() 来获取字符串。 字符串转换为十六进制格式字符串 以下是一个示例代码: const str = ‘hel…

    JavaScript 2023年5月19日
    00
  • Textbox控件注册回车事件及触发按钮提交事件具体实现

    Textbox控件注册回车事件及触发按钮提交事件是Web开发中常用的技术之一。下面我将详细讲解如何实现这个功能。 注册回车事件 在Textbox控件中,我们可以向其绑定keypress事件,通过该事件判断当用户按下回车键时执行某些操作,比如提交表单等。下面是一个简单示例: <input type="text" id="my…

    JavaScript 2023年6月11日
    00
  • JavaScript面向对象程序设计教程

    JavaScript面向对象程序设计教程攻略 什么是面向对象? 面向对象是一种编程范式,它将数据和行为组织在一起,描述真实世界中的事物,并允许程序员定义这些事物的相关操作。在JavaScript中,面向对象编程可以通过对象的创建来实现。 JavaScript中的面向对象 JavaScript是一种基于原型的面向对象语言。它通过原型链来实现继承和数据共享,这种…

    JavaScript 2023年5月27日
    00
  • Javascript基础知识(三)BOM,DOM总结

    Javascript基础知识(三)BOM,DOM总结 BOM(浏览器对象模型) 浏览器对象模型(BOM)提供了一组与浏览器窗口有关的对象,有助于操作浏览器窗口和屏幕显示。BOM是由浏览器厂商自行定义的,因此不属于W3C标准。 BOM的核心对象是window对象,表示浏览器窗口和页面。window对象还可以通过自身属性和方法来操作浏览器窗口、页面、框架、历史记…

    JavaScript 2023年6月10日
    00
合作推广
合作推广
分享本页
返回顶部