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

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

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

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

function sum(x,y){ 
     
    alert(x+y);  
}

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

var ss = function(x,y){ 
     
    alert(x+y);  
}; 

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

sun(1,2);    //3
function sum(x,y){ 
     
    alert(x+y);  
}

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

ss(1,2);    //报错,函数未定义
var ss = function(x,y){ 
     
    alert(x+y);  
};

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

(function(x,y){ alert(x+y);  })(1,2); //3

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

(function(x,y){ alert(x+y);  }(1,2)); //3(括号在里面)

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

void function(x) { 
   
      x = x-1;
      alert(x);
}(9);    //8

2、匿名函数前加 !

!function () { x = x-1; alert(x); }(9);   //8

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

-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、匿名函数前加波浪符(~)

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

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

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

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

new function(win){ 
   
   console.log(win) // window
}(this);

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

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

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

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

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何证明哈夫曼树是最优二叉树_哈夫曼树完全二叉树

    如何证明哈夫曼树是最优二叉树_哈夫曼树完全二叉树一、定义一些定义:节点之间的路径长度:在树中从一个结点到另一个结点所经历的分支,构成了这两个结点间的路径上的经过的分支数称为它的路径长度树的路径长度:从树的根节点到树中每一结点的路径长度之和。在结点数目相同的二叉树中,完全二叉树的路径长度最短。结点的权:在一些应用中,赋予树中结点的一个有某种意义的实数。结点的带权路径长度:结点到树根之间的路径长度与该结点上权的乘积。树的带权路径长度(Weighte…

    2025年7月5日
    4
  • 统计学中ROC曲线的认识

    统计学中ROC曲线的认识ROC曲线的横坐标表示一个负的实例被当作正实例的概率(FPR),纵坐标表示一个正的实例被当作正的实例的概率(TPR)。ROC曲线标识了,为了达到某个TPR,伴随而来的该分类器的FPR是多少当把所有的实例都分类成正的以后,TPR为100%,FPR也是100%,这解释了为什么ROC曲线必然过点(100%,100%)。同理,如果把所有的实例都判为负类,那么,TPR为0,FPR也为0,所以

    2022年5月16日
    57
  • JavaScript判断数组中是否包含某个值「建议收藏」

    JavaScript判断数组中是否包含某个值「建议收藏」有下面几种方法可以实现:方法一:array.indexOf判断数组中是否存在某个值,如果存在,则返回数组元素的下标,否则返回-1。letarr=[1,2,3,4];letindex=arr.indexOf(3);console.log(index);方法二:array.includes(searcElement[,fromIndex])此方法判断数组中是否存在某个值,如果存在返回true,否则返回falseletarr=[1,2,3,4];if(arr.includes(3))

    2022年10月7日
    2
  • 手把手教你如何将图片“嵌入”网页中

    手把手教你如何将图片“嵌入”网页中将图片“嵌入”网页中

    2022年5月27日
    82
  • GCC、ARM-LINUX-GCC、ARM-ELF-GCC浅析

    一、GCC简介:TheGNUCompilerCollection,通常简称GCC,是一套由GNU开发的编译器集,为什么是编辑器集而不是编译器呢?那是因为它不仅支持C语言编译,还支持C++,A

    2021年12月27日
    52
  • 史上最强 Java 学习路线图!

    网上看到一首诗:“代码尽头谁为峰,一见秃头道成空。编程修真路破折,一步一劫渡飞升。”感觉还挺有意境的。第一部分:Java基础篇这个阶段就是编程入门,掌握Java这门编程语言的基本语法,为后面的修行之路打好基础。包括的知识点有:环境搭建——IntellijIDEA一站式搞定Java基础语法面向对象——封装、继承、多态数组字符串集合框架IO反射注解网络编程并发编程这方面的资源我给大家梳理下:1)针对IntellijIDEA,GitHub上有一份简体中文版教

    2022年4月11日
    68

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号