JavaScript中立即执行函数格式有哪些

技术JavaScript中立即执行函数格式有哪些这篇文章主要介绍JavaScript中立即执行函数格式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在JavaScript中有时候看到一些很神

本文主要介绍了JavaScript中立即执行函数的格式,非常详细,有一定的参考价值。感兴趣的朋友一定要看!

有时候你会在JavaScript中看到一些惊人的功能,比如下面的截图:

JavaScript中立即执行函数格式有哪些

只要浏览器加载,这种函数就会自动运行,但需要调用。这种函数在前面的闭包中也提到过,一般叫做:立即执行函数。

立即函数的特征:

会自动执行。

只会执行一次。

00-1010立即执行功能一般有以下格式:

#格式1 (//W3C建议这样写)

(函数(){ 0

}())

#格式2(但这是最常用的方式之一)

(函数(){ 0

})();其实从上面可以看出,函数的立即执行一般不写函数名,意义不大。毕竟,立即函数不需要通过函数名来调用,这类似于函数的字面定义。

现在让我们通过结合闭包和立即执行函数来举一个例子:

varfun=(

函数(){ 0

功能测试(a,b){ 0

console . log(a b);

}

returntest

}

)JavaScript中立即执行函数格式有哪些

00-1010,但是还有其他方法可以实现这个功能。例如,下面的不是上面的格式。

!函数(){ 0

console . log(' test ');

}()9502.163.com

可以看到两个输出行,第一个是test,即有立即执行函数的结果,true是输出,因为前面有更多!这是在隐式转换中说的,在!下面将强制布尔类型换行。

现在还有一个问题,为什么这种方式可以实现?

要分析这种情况的发生,首先需要一个表达式函数:

var test=function(){ 0

Console.log('测试表达式')

}

#如何使用此语句?如下

test();JavaScript中立即执行函数格式有哪些

这时,有一个大胆的想法。赋值的函数可以用变量值()来执行,为什么不能直接写?

var test=function(){ 0

Console.log('测试表达式')

}()9504.163.com

这里可以看到,表达式函数也有即时执行效果。

(补充:为什么都是未定义的值?因为这个函数本身没有返回值,所以在浏览器控制台面板中会输出未定义的值。)

能不能直接在函数后面加括号?

函数(){ 0

Console.log('测试表达式')

}()

112/337998.png" alt="JavaScript中立即执行函数格式有哪些">

可以看出需要用表达式前提才可以在后面放(),不然会报错。

这个时候就有了一个大胆的想法,其实!后面方法,其实将函数转换成立表达式函数,所以后面可以+()可以直接运行了。那就有了大胆的想法,既然如此那直接在函数前加一个加号(+)试试。

+function(){
    console.log("test表达式")
}()

JavaScript中立即执行函数格式有哪些

既然加号可以那么:

+ -
~

当然所谓的乘号和除号是无法实现的,还有一个神奇的关键字也可以有这个神奇的效果,那就是new 和 void

new function(){
    console.log("test表达式")
}()

JavaScript中立即执行函数格式有哪些

还有一个那就是量逻辑运算符号 || 和&& 也可以实现

不过这个需要根据其特征再前面需要加真或者假才可以,单独使用是不可以的

1 && function(){
    console.log("test表达式")
}()
 或者
0 || function(){
    console.log("test表达式")
}()

JavaScript中立即执行函数格式有哪些

还有一个神奇的符号(逗号)也可以实现这个功能:

1,function(){
    console.log("test表达式")
}()

JavaScript中立即执行函数格式有哪些

可以看出如果使用逗号,无论前面真假都会执行后面的表达式函数。

立即执行函数可以带参数

立即执行函数也可以有参数的,具体如下

(function(a,b){
    console.log(a,b)
})(1,2)

JavaScript中立即执行函数格式有哪些

应用

这个题是很经典的面试题,首先创建下一个html

<!DOCTYPE html>
<html>
<head> 
<meta charset="utf-8"> 
<title>test</title> 
</head>
<body>
<ul id=”test”>
    <li>这是第一条</li>
     <li>这是第二条</li>
    <li>这是第三条</li>
 </ul>
<script>
  var liList=document.getElementsByTagName('li');
     for(var i=0;i<liList.length;i++)
     {
         liList[i].onclick=function(){
             console.log(i);
         }
     };
</script>
 </body>
</html>

目的是点击第几个标签li 输出几,但是结果

JavaScript中立即执行函数格式有哪些

因为在点击li的时候for循环早已循环完毕了,这个可以用前面所学的let,关键字也可以解决

  var liList=document.getElementsByTagName('li');
     for(let i=0;i<liList.length;i++)
     {
         liList[i].οnclick=function(){
             console.log(i);
         }
     };

JavaScript中立即执行函数格式有哪些

这个可以解决这个问题,但是没有用到立即运行函数,当然也可以通过立即执行函数进行修改

 var liList=document.getElementsByTagName('li');
     for(let i=0;i<liList.length;i++)
     {  (function(a){
        liList[a].οnclick=function(){
             console.log(a);
         } 
      })(i)
      };

JavaScript中立即执行函数格式有哪些

可以看出立即执行函数会形成一个自己的封闭空间,其不会被外部的其他变量影响,其实这个如果再有一个return的话就是一个标准的闭包了。

以上是“JavaScript中立即执行函数格式有哪些”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/86567.html

(0)

相关推荐

  • 户部掌管什么,古代掌管财政的是什么官员

    技术户部掌管什么,古代掌管财政的是什么官员中国古代专门掌管户籍财经的机关称为:户部   户部为六部之一,长官为户部尚书,曾称地官、大司徒、计相、大司农等户部掌管什么。   户部起源于先秦,《周庄》记载此职为“地官大司徒”

    生活 2021年10月25日
  • MySQL如何在线开启/关闭GTID

    技术MySQL如何在线开启/关闭GTID小编给大家分享一下MySQL如何在线开启/关闭GTID,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!一

    攻略 2021年11月6日
  • css中如何去掉i的斜体样式

    技术css中如何去掉i的斜体样式本篇内容主要讲解“css中如何去掉i的斜体样式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“css中如何去掉i的斜体样式”吧!

    攻略 2021年11月11日
  • Java中Future和FutureTask怎么用

    技术Java中Future和FutureTask怎么用小编给大家分享一下Java中Future和FutureTask怎么用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一、Future 接口当 call

    攻略 2021年11月30日
  • js判断某个元素是否有指定的class名的方法有哪些

    技术js判断某个元素是否有指定的class名的方法有哪些这篇文章主要介绍“js判断某个元素是否有指定的class名的方法有哪些”,在日常操作中,相信很多人在js判断某个元素是否有指定的class名的方法有哪些问题上存在疑

    攻略 2021年11月5日
  • 大数据治理中如何搭建大数据探索平台

    技术大数据治理中如何搭建大数据探索平台这篇文章给大家介绍大数据治理中如何搭建大数据探索平台,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。在数据治理中,数据探索服务的价值在初期往往是被忽视的,但是随着

    攻略 2021年12月10日