一次搞定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("立即执行函数")
}()
相关推荐
凌辰揽月1 分钟前
AJAX 学习
java·前端·javascript·学习·ajax·okhttp
然我2 小时前
防抖与节流:如何让频繁触发的函数 “慢下来”?
前端·javascript·html
鱼樱前端2 小时前
2025前端人一文看懂 Broadcast Channel API 通信指南
前端·vue.js
烛阴2 小时前
非空断言完全指南:解锁TypeScript/JavaScript的安全导航黑科技
前端·javascript
鱼樱前端2 小时前
2025前端人一文看懂 window.postMessage 通信
前端·vue.js
快乐点吧3 小时前
【前端】异步任务风控验证与轮询机制技术方案(通用笔记版)
前端·笔记
pe7er3 小时前
nuxtjs+git submodule的微前端有没有搞头
前端·设计模式·前端框架
七月的冰红茶3 小时前
【threejs】第一人称视角之八叉树碰撞检测
前端·threejs
爱掉发的小李3 小时前
前端开发中的输出问题
开发语言·前端·javascript
祝余呀4 小时前
HTML初学者第四天
前端·html