前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >匿名函数自调用_自己调用自己的函数叫

匿名函数自调用_自己调用自己的函数叫

作者头像
全栈程序员站长
发布于 2022-11-09 08:32:48
发布于 2022-11-09 08:32:48
2.6K00
代码可运行
举报
运行总次数:0
代码可运行

我们知道一个HTML文件在被加载的时候是从根标签html依次往下的,在遇到link,script等标签引入的外部资源时,下载外部资源,并执行外部资源。在js中,表达式会被立即执行,也就是说,不管是引入的外部js文件还是嵌入在html文件中的js脚本,其中的表达式都会被立即执行。 函数名是一个指向函数的指针。在JavaScript中,定义函数有常见的两种形式:函数声明和函数直接量(或者叫函数表达式)。 函数声明:采用function定义声明函数的标准写法,包括function,函数名,函数体。如

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
function sum(x,y){ 
     
    alert(x+y);  
}

函数表达式:定义一个匿名函数,并赋值给一个变量。如

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
var ss = function(x,y){ 
     
    alert(x+y);  
}; 

函数表达式有多种形式,后面会一一介绍。 关于函数声明,它最重要的一个特征就是函数声明提升,意思是执行代码之前先读取函数声明。这意味着可以把函数声明放在调用它的语句之后。例

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
sun(1,2;    //3
function sum(x,y){ 
     
    alert(x+y);  
}

而函数表达式在编译的时候不会被提前,如下调用函数将会报错

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
ss(1,2);    //报错,函数未定义
var ss = function(x,y){ 
     
    alert(x+y);  
};

介绍了函数的定义以及JavaScript的编译规则,下面正式说一下匿名函数自调用。当我们给匿名函数外面加上一层()的时候,匿名函数就变成了函数表达式,在JavaScript编译的时候就会被立即执行。如

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
(function(x,y){ alert(x+y);  })(1,2); //3

除了用()把匿名函数包起来之外,后面还需要再跟一个(),可以通过此()给匿名函数传参。 变形写法:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
(function(x,y){ alert(x+y);  }(1,2)); //3(括号在里面)

匿名函数自调用的写法有很多,下面列举常见的几种写法 1、匿名函数前加 void

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
void function(x) { 
   
      x = x-1;
      alert(x);
}(9);    //8

2、匿名函数前加 !

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
!function () { x = x-1; alert(x); }(9);   //8

3、匿名函数前加 +/-运算符

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
-function(x,y){ 
   
    alert(x+y);
    return x+y;
}(3,4);

+function(x,y){ 
   
    alert(x+y);
    return x+y;
}(3,4);

--function(x,y){ 
   
    alert(x+y);
    return x+y;
}(3,4);

++function(x,y){ 
   
    alert(x+y);
    return x+y;
}(3,4);

运算符不起运算作用,只是为了把匿名函数变成一个表达式 4、匿名函数前加波浪符(~)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
~function(x, y) { 
   
    alert(x+y);
   return x+y;
}(3, 4);

5、匿名函数执行放在中括号内

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
[function(){ 
   
   console.log(this) // 浏览器得控制台输出window
}(this)];

6、匿名函数前加new ,typeof ,delete等

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
new function(win){ 
   
   console.log(win) // window
}(this);

typeof function(){ 
   
   console.log(this) // 浏览器得控制台输出window
}(this);

delete function(){ 
   
   console.log(this) // 浏览器得控制台输出window
}(this);

只要记住一点,匿名函数前面加的任何运算符、操作符都不起运算和操作作用,而只是为了把匿名函数包装成一个表达式执行!!!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/186293.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年10月3日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档