一次搞定JS立即执行函数

前言


😬在我们进行平时的开发时候我们经常会使用函数,但是我们并不经常使用立即执行函数,这篇文章我们将讲解下立即执行函数的使用以及不同的写法与使用场景。

一.立即执行函数


🐔立即执行函数顾名思义就是在定义完成之后直接就执行的函数,立即执行函数的定义有两个部分。

  1. 第一部分定义了一个匿名函数()表示这个函数有自己独立的作用域。
  2. 第二部分()表示这个函数被执行了。
js 复制代码
(
  function () {
    console.log("Hello World")
  }
)()

😳立即执行函数的变量传递方式:

js 复制代码
(
  function (name) {
    console.log(name)
  }
)('约翰')

🐸立即执行函数的应用场景


  1. 实现变量私有解决命名冲突
js 复制代码
var count = 100
let sum = (
  function () {
    var count = 0
    function foo () {
      count++
      console.log(count)
    }
    return {
      foo: foo
    }
  }
)()
sum.foo() // 1
console.log(count) // 100
  1. 在原生开发中进行接口请求初始化数据
js 复制代码
(function() {
  // 初始化 AJAX 对象
  var xhr = new XMLHttpRequest();

  // 设置回调函数
  xhr.onreadystatechange = function() {
    if (xhr.readyState === 4 && xhr.status === 200) {
      var response = JSON.parse(xhr.responseText);
      // 处理响应数据
    }
  };

  // 发送 AJAX 请求
  xhr.open('GET', 'https://api.example.com/data', true);
  xhr.send();
})();

🐣立即执行函数的其他写法,除了上述的写法外,下列这些写法也可以进行函数的立即执行,但是不推荐。

js 复制代码
+function () {
  console.log("立即执行函数")
}()

!function() {
   console.log("立即执行函数")
}();

-function () {
  console.log("立即执行函数")
}()

~function () {
  console.log("立即执行函数")
}()
相关推荐
升讯威在线客服系统20 分钟前
如何通过 Docker 在没有域名的情况下快速上线客服系统
java·运维·前端·python·docker·容器·.net
AsBefore麦小兜22 分钟前
Vite vs Webpack
前端·webpack
LaughingZhu23 分钟前
PH热榜 | 2025-02-23
前端·人工智能·经验分享·搜索引擎·产品运营
道不尽世间的沧桑2 小时前
第17篇:网络请求与Axios集成
开发语言·前端·javascript
diemeng11193 小时前
AI前端开发技能变革时代:效率与创新的新范式
前端·人工智能
bin91535 小时前
DeepSeek 助力 Vue 开发:打造丝滑的复制到剪贴板(Copy to Clipboard)
前端·javascript·vue.js·ecmascript·deepseek
晴空万里藏片云7 小时前
elment Table多级表头固定列后,合计行错位显示问题解决
前端·javascript·vue.js
曦月合一7 小时前
html中iframe标签 隐藏滚动条
前端·html·iframe
奶球不是球7 小时前
el-button按钮的loading状态设置
前端·javascript
kidding7237 小时前
前端VUE3的面试题
前端·typescript·compositionapi·fragment·teleport·suspense