JavaScript系列:函数 自执行 表达式 声明 定义
可用方式
-
(function($) {})(jQuery);
-
!function( $ ){}(jQuery);
-
+function( $ ){}(jQuery);
-
-function( $ ){}(jQuery);
-
~function( $ ){}(jQuery);
更多方式参考http://swordair.com/function-and-exclamation-mark/
本质解释
function() {}()
这么写会报错,因为这是一个函数定义:
修正1:(多了一对括号),调用匿名函数:(function() {})()
。
修正2: 在前面加上一个布尔运算符(只多了一个感叹号),就是表达式了,将执行后面的代码,也就合法实现调用!function() {}()
。
使用括号包裹定义函数体,解析器将会以函数表达式的方式
去调用定义函数。任何何能将函数变成一个函数表达式
的作法,都可以使解析器正确的调用定义函数。
而 !
, +
, -
,||
都有这样的功能。
函数(声明和表达式)个人常用函数声明,因为放在调用的上面还是下面都不出错
函数声明不仅会提升声明,还会提升定义
fun() // 调用成功
function fun() {}
函数表达式只会提升声明,不会提升定义
fun() // 有foo这个变量,但它却不是函数,所以调用失败
var fun = function() {}
变量提升
不论函数的表达式还是声明,都是变量(函数字面量),变量(声明)提升
知识没有高低贵贱之分。
分类:
javascript
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?