js自调用函数和闭包

什么是自调用函数?

自调用函数就是自己执行的函数,即自调用函数声明完成后立即执行。

普通函数:

<script>
	//创建函数
	function func1(parameter1,parameter2){
		var sum;
		sum = parameter1 + parameter2;
		return sum;
	}
	//调用函数
	number = func(1,2);//number = 3
</script>

先声明函数,再调用传入实参。

自调用函数则是:

<script>
	(function(num){
		return num;
	})();
</script>

同时完成了声明和调用。

### 闭包自调用函数的概念 #### 闭包JavaScript 中,闭包是指一个函数能够记住并访问它的词法作用域,即使这个函数在其词法作用域之外执行。这意味着闭包可以捕获并保存其外部环境的状态[^1]。 ```javascript function createCounter() { let count = 0; return function () { count += 1; return count; } } const counter = createCounter(); console.log(counter()); // 输出: 1 console.log(counter()); // 输出: 2 ``` 这段代码展示了如何通过闭包来创建计数器。每次调用 `counter` 函数时,它都会增加并返回之前定义的 `count` 变量的值。这体现了闭包的一个重要特性:它可以保持对外部变量的引用,从而实现数据封装持久化存储[^3]。 #### 自调用函数(立即执行函数表达式) 自调用函数是一种特殊的匿名函数形式,会在被解释的同时立刻被执行。这种模式通常用于创建独立的作用域链,防止全局污染,并且可以在不暴露任何内部逻辑的情况下完成特定任务[^4]。 ```javascript (function immediateFunction() { console.log('这是来自自调用函数的消息'); })(); // 或者更简洁的形式: (() => { console.log('箭头函数版本'); })(); ``` 这两种方式都实现了相同的效果—即刻运行一段代码而不影响外界环境。值得注意的是,由于这些函数是在定义之后马上就被调用了,因此无法再重复使用它们;如果需要多次调用,则应该考虑将其赋给某个变量作为常规命名或匿名函数处理。 ### 应用场景对比 对于 **闭包** 来说: - 实现模块化的编程风格; - 构建工厂方法生成具有不同状态的对象实例; - 维护私有的成员属性服务端口连接等长期存在的资源管理操作[^2]。 而对于 **自调用函数** 而言: - 隐藏不必要的细节以减少潜在冲突的风险; - 初始化某些配置项或者启动应用程序的核心部分; - 执行一次性设置工作比如加载脚本文件、初始化插件等功能。 ### 总结 虽然两者都是基于函数的基础之上构建而成的技术手段,但是各自有着不同的侧重点以及适用范围。理解这两者的差异不仅有助于提高编码效率,还能让开发者写出结构清晰、易于维护的应用程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值