广告
返回顶部
首页 > 资讯 > 精选 >JavaScript中立即执行函数格式有哪些
  • 170
分享到

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

2023-06-25 15:06:41 170人浏览 八月长安
摘要

这篇文章主要介绍javascript中立即执行函数格式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在JavaScript中有时候看到一些很神奇的函数比如下面截图:这种函数只要浏览器加载的时候会自动运行,而需要

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

在JavaScript中有时候看到一些很神奇的函数比如下面截图:

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

这种函数只要浏览器加载的时候会自动运行,而需要调用,前面在闭包的时候也说过这种函数,一般将其称之为:立即执行函数。

立即函数的特征:

  • 会自动执行

  • 只会执行一次

立即执行函数格式

立即执行函数一般有格式如下:

# 格式一(//W3C 推荐这种写法)(function (){ }()) #格式二 (但是这个才是最常用的方式之一)(function (){ })();

其实上面还可以看出立即执行函数,一般都不会写函数名字,其意义不大,毕竟立即函数不必通过函数名进行调用了,这个和字面量定义函数的时候作用差不多。

现在结合闭包和立即执行函数相互结合来一个例子:

var fun=(function(){  function test(a,b){      console.log(a+b);  }      return test;})()

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

立即执行函数其他方式–表达式

上面的立即执行函数的格式定义,但是还有其他方式实现这个功能,比如下面这个就不是上面的格式

!function(){    console.log("test");}()

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

看出其输出的两行,第一个是test,也就是有种立即执行函数的结果,而true被输出是是因为前面多了!,这个在隐式转换的时候说过,在!后面的都会强制换行布尔类型。

现在又有一个疑问了,为什么这种方式可以实现呢?

分析这种情况的产生,首先来一个表达式函数:

var test=function(){    console.log("test表达式")}#这样声明后,如何使用呢?如下test();

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

这个时候就有一个大胆的想法了,赋值的函数,通过变量值+()就可以执行,那为什么不能直接写好。

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

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

这地方可以看出 表达式函数也有了一种立即执行的效果。

(补充:为什么都有undefined,因为这个函数本身就没有return 值,所以会有undefined这个值在浏览器console面板输出了undefined)

那直接在函数后面放括号可以吗?

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

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中立即执行函数格式有哪些”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注编程网精选频道!

--结束END--

本文标题: JavaScript中立即执行函数格式有哪些

本文链接: https://www.lsjlt.com/news/305526.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • JavaScript中立即执行函数格式有哪些
    这篇文章主要介绍JavaScript中立即执行函数格式有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在JavaScript中有时候看到一些很神奇的函数比如下面截图:这种函数只要浏览器加载的时候会自动运行,而需要...
    99+
    2023-06-25
  • JavaScript基础之立即执行函数
    目录立即执行函数格式立即执行函数其他方式–表达式立即执行函数可以带参数应用总结在JavaScript中有时候看到一些很神奇的函数比如下面截图: 这种函数只要浏览器加载的时候会自动运...
    99+
    2022-11-12
  • JavaScript立即执行函数用法解析
            我们知道,在一般情况下,函数必须先调用才能执行,如下所示,我们定义了一个函数,并且调用, fu...
    99+
    2022-11-12
  • Javascript立即执行函数(IIFE)实例详解
    目录前言函数表达式立即执行函数如果我们了解整个情况:IIFE 的特征/行为附:IIFE的参数总结前言 IIFE,一般称为立即执行函数。你可能会问我,*“嘿!我知道正常的函...
    99+
    2022-11-13
  • JavaScript立即执行函数与函数劫持的作用
    目录一、立即执行函数1、实现方式2、立即执行函数的作用3、使用场景4、返回值5、带单目运算符的立即执行函数二、函数劫持一、立即执行函数 立即执行函数(IIFE):在函数声明后立即调用...
    99+
    2023-01-11
    JS立即执行函数 JS函数劫持
  • javascript立即执行函数表达式IIFE的示例分析
    这篇文章主要为大家展示了“javascript立即执行函数表达式IIFE的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“javascript立即执行函数...
    99+
    2022-10-19
  • JavaScript立即执行函数的用法是什么
    JavaScript立即执行函数的用法是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。       ...
    99+
    2023-06-22
  • php命令执行函数有哪些
    php中的命令执行函数有System、Exec和Passthru几种System函数System函数作用:php中System函数的作用是用于执行command参数所指定的命令,且打印全部的输出值。System函数语法:system ( s...
    99+
    2022-10-06
  • Mysql中有哪些格式化日期函数
    这期内容当中小编将会给大家带来有关Mysql中有哪些格式化日期函数,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。  DATE_FORMAT(date,format)根据格...
    99+
    2022-10-18
  • JavaScript中函数的参数形式有哪些
    JavaScript中函数的参数形式有哪些?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.函数参数function sum(param1, param2)...
    99+
    2023-06-14
  • JavaScript正则表达式函数有哪些
    这篇文章主要为大家展示了“JavaScript正则表达式函数有哪些”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JavaScript正则表达式函数有哪些”这篇文...
    99+
    2022-10-19
  • JavaScript 中回调函数有哪些
    这期内容当中小编将会给大家带来有关JavaScript 中回调函数有哪些,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。什么是函数函数是在其中有一组代码的逻辑构件,用来执行...
    99+
    2022-10-19
  • javascript中的函数都有哪些
    本篇内容主要讲解“javascript中的函数都有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“javascript中的函数都有哪些”吧!按字母排序:abs acos action aler...
    99+
    2023-06-03
  • MySQL中常用DDL执行方式有哪些
    这篇文章将为大家详细讲解有关MySQL中常用DDL执行方式有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 操作   &nbs...
    99+
    2022-10-18
  • JavaScript函数参数的传递方式有哪些
    这篇文章主要介绍了JavaScript函数参数的传递方式有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JavaScript使用一个变量...
    99+
    2022-10-19
  • MySQL日期函数与日期转换格式化函数有哪些
    这篇文章将为大家详细讲解有关MySQL日期函数与日期转换格式化函数有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Mysql作为一款开元的免费关系型数据库,用户基础非...
    99+
    2022-10-18
  • javascript中深拷贝函数有哪些
    这篇文章将为大家详细讲解有关javascript中深拷贝函数有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。JavaScript可以做什么1.可以使网页具有交互性,例如响应用户点击,给用户提供更好的体...
    99+
    2023-06-14
  • JavaScript中的系统函数有哪些
    这篇文章主要介绍JavaScript中的系统函数有哪些,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1.encodeURI("");返回一个URI字符串编码后的结果:var urlStr=enco...
    99+
    2023-06-03
  • Ajax中外部数据格式有哪些
    小编给大家分享一下Ajax中外部数据格式有哪些,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!HTML优点:HTML片段实现起来只...
    99+
    2022-10-19
  • java中有哪些函数式接口
    java中有哪些函数式接口?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。常用的java框架有哪些1.SpringMVC,Spring Web MVC是一种基于J...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作