一次搞定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("立即执行函数")
}()
相关推荐
用户69371750013847 小时前
Google 正在“收紧侧加载”:陌生 APK 安装或需等待 24 小时
android·前端
蓝帆傲亦7 小时前
Web 前端搜索文字高亮实现方法汇总
前端
用户69371750013847 小时前
Room 3.0:这次不是升级,是重来
android·前端·google
漫随流水8 小时前
旅游推荐系统(view.py)
前端·数据库·python·旅游
踩着两条虫9 小时前
VTJ.PRO 核心架构全公开!从设计稿到代码,揭秘AI智能体如何“听懂人话”
前端·vue.js·ai编程
jzlhll12310 小时前
kotlin Flow first() last()总结
开发语言·前端·kotlin
蓝冰凌11 小时前
Vue 3 中 defineExpose 的行为【defineExpose暴露ref变量】详解:自动解包、响应性与实际使用
前端·javascript·vue.js
奔跑的呱呱牛11 小时前
generate-route-vue基于文件系统的 Vue Router 动态路由生成工具
前端·javascript·vue.js
柳杉12 小时前
从动漫水面到赛博飞船:这位开发者的Three.js作品太惊艳了
前端·javascript·数据可视化