首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

立即执行函数

立即执行函数(IIFE),也叫做自执行函数,就是不需要调用就立马执行函数。...() { } 立即函数有两种常见格式: (function() { console.log(999) }()) (function() { console.log(999) })() 这两种格式都能保证函数立马执行...,这也是立即函数的基础常见的格式,()运算符加上匿名函数,还有另外几种格式也能立即执行: !...、+、-、=和函数表达式都能打到立即执行。上面的方法,是匿名函数加上运算符,其实把匿名函数都换成函数声明也是一样的,也能变成立即执行函数: !...我们都知道JavaScript没有块级作用域,只要函数作用域,立即函数最大的用途就是创建一个函数作用域,也就是创建一个私有的空间。

1.6K40
您找到你想要的搜索结果了吗?
是的
没有找到

js 立即执行函数

立即执行函数 目录 立即执行函数 作用 参数 返回值 立即执行函数 立即执行函数模式是一种语法,可以让你的函数在定义后立即执行。...立即执行函数的组成 定义一个函数 将整个函数包裹在一对括号中 将函数声明转换为表达式 在结尾加上一对括号 让函数立即执行 代码实例 (function () { console.log("...app") })() 作用 页面加载完成后只执行一次的设置函数。...注意 通常你不应该给立即执行函数传递太多的参数,因为它很快会成为一个负担——为了理解代码是如何工作的,你不得不经常上下滚动源代码。...返回值 就像其它任何函数一样,一个立即执行函数也能返回值并且可以赋值给其它变量。 var num = (function () { return 4 })() console.log(num)

6.1K20

理解JavaScript立即执行函数

IIFE (Immediately Invokable Function Expressions):是在函数声明后立即调用的函数表达式。...立即执行函数通常包含两种使用格式,具体使用那一种风格可以根据个人习惯和团队规范选择: // 第一种: (function() {/* */})(); // 第二种: (function(){/* */...}()) // 也可以使用箭头函数声明 ;(() => {/* */}()) 数学符号都会导致函数立即执行,因为JavaScript引擎会将函数判断为表达式,而不是函数声明。...function(){}(); +function(){}(); -function(){}(); ~function(){}(); new关键字也会导致函数立即执行。...: 避免污染全局 在JavaScript函数内部,会形成一个块级作用域的概念,可以利用IIFE函数避免全局污染,比如JQuery插件的封装模式:(function($){ ``` //JQuery

1.1K30

js匿名函数立即执行函数

js匿名函数立即执行函数 1. 匿名函数 a)写法 b) 特点 2. 立即执行函数 a) 写法 b) 特点 c) 示例 1. 匿名函数 匿名函数又叫拉姆达函数, 使用前需要先赋值。...(使用关键字var定义的),但不能访问外层署名函数的属性(使用关键字this定义的) 匿名函数既可以直接访问外层匿名函数中的变量,也可以直接访问外层匿名函数中的属性 外层函数类型: 署名函数 匿名函数...立即执行函数 该类函数没有声明,直接执行执行立即释放。一般做初始化比较合适。...console.log("写法一"); }());//w3c建议写法 (function (){ console.log("写法二"); })(); b) 特点 只有表达式才能被执行...,如function (){}(),这样不行,因为function (){}是声明不是表达式,如果是var fn=function (){}();就可以 但执行后,函数名或者变量就不代表函数了,被执行符号执行的表达式其函数名字将被忽略

2.5K20

深入理解立即执行函数

前言 立即执行函数常用于第三方库,它可以用来隔离变量作用域,很多第三方库都会存在大量的变量和函数,在ES5环境下为了避免变量污染,开发者想到的解决办法就是使用立即执行函数。...本文就跟大家分享下立即执行函数的相关知识点,欢迎各位感兴趣的开发者阅读本文。...,当你的代码在不支持ES6+的浏览器上运行时,你不得不求助立即执行函数来模拟。...上述两种写法是等价的,要想立即执行函数做到立即执行,要注意两点: 函数体后面要有小括号 函数体必须是函数表达式而不能是函数声明 函数的声明方式 在讲它们两者之间的区别之前,我们先来了解下js函数的两种声明方式...")); 讲解到此处时,我们会发现,上述代码的写法正好是立即执行函数的第二种写法,我们知道函数体后面跟着小括号,这个函数就会立即执行

1.2K30

你真的知道『立即执行函数』吗?

立即执行函数,经常使用,但是你确定了解它嘛? 下面,就来看看吧! 1、定义 立即执行函数,又称IIFE....叫做执行符号 3、立即执行函数的使用 声明后,直接加(); 将会报语法错误,执行符号只能跟在函数表达式后面 示例: function test(){ console.log('Function declaration...'); }() 报错:Uncaught SyntaxError: Unexpected token ')' 原因:立即执行函数 ,是执行函数表达式,而不是函数声明式 4、函数表达式 当一个函数需要立即执行的情况...且函数名不能在外部使用 8、立即执行函数的好处 1、可以创建一个与外界没有任何关联的作用域,独立作用域 2、执行完成后,自动销毁 3、ES3 ES5 立场上是没有模块的模仿,可用立即执行函数来模拟模块化...今天的分享就到这,还有关于立即执行函数的其它问题,欢迎提问

58820

前端面试之立即执行函数

什么是立即执行函数 声明一个函数,并马上调用这个匿名函数就叫做立即执行函数。在定义好一个函数后,直接执行。...(function() {alert('立即执行函数')})() 用声明一个函数,用括号包起来,调用此函数。...立即执行函数的写法 有时候,我们定义函数以后,立即调用该函数,这时不能在函数的定义后面直接加圆括号,这会产生语法错误。...解决方法: 1、使用立即执行函数,给每个li创建一个独立的作用域,在立即执行函数执行的时候,i的值从0到2,对应三个立即执行函数,所以就能正常输出了。...立即执行函数的参数 (function(i) { ... })(j) 如果立即执行函数中需要全局变量,全局变量会被作为一个参数传递给立即执行函数。j代表是实参,i代表的是执行函数的形参。

1.6K10

JavaScript立即执行函数(IIFE)的使用

js的立即执行函数(IIFE)有两种写法,分别为:(function ( ){})( ) 与 (function ( ){}( )) ,这两种写法基本上是没有区别的。 那么为什么要 IIFE?...1.传统的方法啰嗦,定义和执行分开写; 2.传统的方法直接污染全局命名空间(浏览器里的 global 对象,如 window) 函数范围与块范围界定 使用var关键字声明的局部变量的作用域为封闭函数。...foo; // ReferenceError: foo is not defined 但是,块范围变量不能替代立即调用的函数表达式。...通过这种方式,即使函数在IIFE的词法范围外执行,也会创建一个闭包,使函数能够访问局部变量。...捕获全局对象 JavaScript代码在不同环境执行时,你所使用的全局对象是不同的。当代码在浏览器运行时,全局对象是windows。但是在Node.js中,全局对象是global。

2.2K20

立即执行函数表达式(IIFE)

立即执行函数表达式(IIFE) 幸运的是,固定的语法错误很简单。最普遍接受的方式告诉解析器这是一个被括号包裹的函数表达式。...这一括号通常意味着函数表达式会被立即执行,变量将包含函数的结果而不是函数本身。这也会解决一些麻烦,否则如果你写了一个很长的函数表达式,别人必须拉到最底部查看该函数有没有被立即执行。...闭包的存储状态 就像函数函数名调用时参数会被传递一样,立即执行函数表达式时参数同样会被传递。因为在一个函数内部定义的函数可以访问外部函数的变量(这种关系被称为闭包)。...立即执行函数表达式最好的一方面就是,因为这个匿名函数表达式被立即执行,没有标识符,所以闭包的使用不会污染当前作用域。 “自执行匿名函数”有错误吗?...“立即执行函数表达式”是什么?它是一个被立即执行函数表达式,就像这个名称会让你相信一样。 我希望看到 JavaScript 社区成员在他们的文章和报告中采用“立即执行函数表达式”这个术语。

87650

JavaScript之闭包问题以及立即执行函数

首先我们先要了解一下关于立即执行函数: ( function(){…} )()和( function (){…} () )是两种javascript立即执行函数的常见写法,最初我以为是一个括号包裹匿名函数...,再在后面加个括号调用函数,最后达到函数定义后立即执行的目的,后来发现加括号的原因并非如此。...要理解立即执行函数,需要先理解一些函数的基本概念。...,而函数表达式必须等到Javascirtp引擎执行到它所在行时,才会从上而下一行一行地解析函数表达式; 二、函数表达式后面可以加括号立即调用该函数函数声明不可以,只能以fnName()形式调用 。...(){…} () )这两种立即执行函数的写法,最初我以为是一个括号包裹匿名函数,并后面加个括号立即调用函数,当时不知道为什么要加括号,后来明白,要在函数体后面加括号就能立即调用,则这个函数必须是函数表达式

88620

箭头函数

箭头函数(★★★) ES6中新增的定义函数的方式。...() => {} //():代表是函数; =>:必须要的符号,指向哪一个代码块;{}:函数体 const fn = () => {}//代表把一个函数赋值给fn 函数体中只有一句代码,且代码的执行结果就是返回值...this);//this 指向 是obj对象 return () => { console.log(this);//this 指向 的是箭头函数定义的位置,那么这个箭头函数定义在...this,箭头函数中的this指向是它所定义的位置,可以简单理解成,定义箭头函数中的作用域的this指向谁,它就指向谁 箭头函数的优点在于解决了this执行环境所造成的一些问题。...比如:解决了匿名函数this指向的问题(匿名函数执行环境具有全局性),包括setTimeout和setInterval中使用this所造成的问题 面试题 var age = 100; ​ var

1.1K20

function前加运算符实现立即执行函数

我们知道函数的调用方式通常是FunctionName() 但如果我们尝试为一个“定义函数”末尾加上(),解析器是无法理解的。...function msg(){ alert('message'); }();//解析器是无法理解的 定义函数的调用方式应该是 msg()。 想让函数立即执行可以将函数体部分用()包裹起来。...这是因为,使用括号包裹定义函数体,解析器将会以函数表达式的方式去调用定义函数。也就是说,任何能将函数变成一个函数表达式的作法,都可以使解析器正确的调用定义函数。...(只多了一个感叹号),就是表达式了,将执行后面的代码,也就合法实现调用 !...效果等同于以下常用的两种立即执行方式: (function() {})(); // or (function() {}()); 谢谢大家的阅读。

97620
领券