一次搞定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("立即执行函数")
}()
相关推荐
我要洋人死43 分钟前
导航栏及下拉菜单的实现
前端·css·css3
科技探秘人1 小时前
Chrome与火狐哪个浏览器的隐私追踪功能更好
前端·chrome
科技探秘人1 小时前
Chrome与傲游浏览器性能与功能的深度对比
前端·chrome
JerryXZR1 小时前
前端开发中ES6的技术细节二
前端·javascript·es6
七星静香1 小时前
laravel chunkById 分块查询 使用时的问题
java·前端·laravel
q2498596931 小时前
前端预览word、excel、ppt
前端·word·excel
小华同学ai1 小时前
wflow-web:开源啦 ,高仿钉钉、飞书、企业微信的审批流程设计器,轻松打造属于你的工作流设计器
前端·钉钉·飞书
Gavin_9151 小时前
【JavaScript】模块化开发
前端·javascript·vue.js
懒大王爱吃狼2 小时前
Python教程:python枚举类定义和使用
开发语言·前端·javascript·python·python基础·python编程·python书籍
逐·風6 小时前
unity关于自定义渲染、内存管理、性能调优、复杂物理模拟、并行计算以及插件开发
前端·unity·c#