在javascript中有引入立即执行函数的概念,那么什么是立即执行函数呢?立即执行函数又是怎么写的呢?立即执行函数与普通函数有什么区别呢?

先来看看一般的函数:

function a(){
var num = 100;
console.log(num);
}

以上就是javascript中随便定义的最普通的函数,函数一旦被定义,就会一直等着被执行,会一直占用空间。除非等到javascript执行完函数才会被释放。但是有些时候不想要这么多空间被占用,因为会浪费效率。有些函数从出生到javascript执行完它就只被执行了一次。这就导致该函数的空间被一直占用。为了避免这种不必要的空间被一直占用,javascript引入了立即执行函数。

(function test(){
var a = 12;
var b = 13;
console.log(a+b);
}())

上边这种写法就是立即执行函数

我们看出函数可以正常执行,但是在执行之后就再也找不到这个函数了。所以立即执行函数我们一般不给他取名字。

同样和普通的函数一样,立即执行函数也可以有参数和返回值。(不能有返回值的函数还要它干嘛啊)

var sum = (function (x,y,z) {
return x+y+z;
}(5,6,7))

这样的话,函数执行完虽然被销毁,但是返回值被num接收。同样也解决了内存占用的问题。

下边是两种常见的立即执行函数的写法

(function (){}());  W3C建议使用第一种
(function (){})();

在开发中,立即执行函数主要用于解决闭包的问题和针对初始化的功能等,在初始化页面时用到的立即执行函数不需要有返回值,但是在初始化页面的时候用到的立即执行函数一定要有返回值。立即执行函数照样有执行期上下文,内部照样执行预编译的环节。

再往深了探究,1.只有表达式才可以被执行符号(小括号)执行。2.能被执行符号执行的表达式他的名字就会自动被忽略。什么意思呢?看下边的例子

先来解释上边的第一句话。我们知道函数的定义分为两种(函数声明和函数表达式)

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

看上边的代码能执行吗?

单写test表示函数的引用,正常情况下想要执行函数直接test(); 函数名加小括号即可,上边的函数声明跟函数引用一样,那直接加一对小括号应该也可以执行呀,结果却不然:

在系统看来这是一个非常低级的语法错误。因为小括号前边的是函数声明,而不是表达式,所以就不能被执行。

再看下边这种写法:

var a = function (){
console.log();
}()

这回小括号前边很明显是表达式,所以就可以执行。

再解释上边的第二句话。

var a = function (){
console.log();
}

现在的a还代表函数的名字呢

在下边执行这个表达式:

var a = function (){
console.log();
}()

这时候的a已经不再表示这个函数名了。

所以:能被执行符号执行的表达式他的名字就会自动被忽略。

类似的:

+function (){
console.log();
}()
-function (){
console.log();
}()
!function (){
console.log();
}()

以上几种情况前边很明显是表达式,所以就可以执行。这回就一目了然为啥整体加个小括号就可以立即执行了吧,因为被小括号括起来就变成了表达式嘛,自然可以执行。

javascript的立即执行函数的更多相关文章

  1. Javascript的自执行函数

    自执行函数其实也就是"立即执行的函数",它有四个特点:提高性能.利于压缩.避免冲突.依赖加载: 1.减少作用域查找 JS代码: // Anonymous function that ...

  2. JavaScript匿名自执行函数~function(){}

    原博客:https://blog.csdn.net/yaojxing/article/details/72784774 1.匿名函数的常见场景 js中的匿名函数是一种很常见的函数类型,比较常见的场景: ...

  3. javascript js自执行函数

    javascript  自执行函数 一.自执行函数几种写法: 写法一: ( function(){ //代码 } )(); 写法二: ( function(){ //代码 }()); 二.作用: 隔离 ...

  4. (转)扫盲--JavaScript的立即执行函数

    看过jQuery源码的人应该知道,jQuery开篇用的就是立即执行函数.立即执行函数常用于第三方库,好处在于隔离作用域,任何一个第三方库都会存在大量的变量和函数,为了避免变量污染(命名冲突),开发者们 ...

  5. JavaScript/JQuery自执行函数

    JavaScript中任何库与框架设计的第一个要点就是解决命名空间与变量污染的问题.jQuery就是利用了JavaScript函数作用域的特性,采用自执行函数包裹了自身的方法来解决这个问题.从jQue ...

  6. JavaScript 函数声明,函数表达式,匿名函数,立即执行函数之区别

    函数声明:function fnName () {-};使用function关键字声明一个函数,再指定一个函数名,叫函数声明. 函数表达式 var fnName = function () {-};使 ...

  7. javascript立即执行函数

    javascript和其他编程语言相比比较随意,所以javascript代码中充满各种奇葩的写法,有时雾里看花;当然,能理解各型各色的写法也是对javascript语言特性更进一步的深入理解.  ( ...

  8. JavaScript 立即执行函数

    js中(function(){…})()立即执行函数写法理解 javascript和其他编程语言相比比较随意,所以javascript代码中充满各种奇葩的写法,有时雾里看花,当然,能理解各型各色的写法 ...

  9. JavaScript:立即执行的函数表达式

    先要理解清楚几个概念:   以下转自:http://www.cnblogs.com/TomXu/archive/2011/12/31/2289423.html  问题的核心 当你声明类似functio ...

随机推荐

  1. Laravel API跨域访问的实现步骤

    本篇文章给大家带来的内容是关于Laravel API跨域访问的实现步骤,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 服务器A请求服务器B的接口,那么一般会出现跨域问题. 1 XML ...

  2. 实验吧——NSCTF web200

    题目地址:http://ctf5.shiyanbar.com/web/web200.jpg 打开就是个自定义加密函数,只要写出相应的解密算法就行 <?php function encode($s ...

  3. elasticsearch组合多条件查询实现restful api以及java代码实现

    原文:http://blog.java1234.com/blog/articles/372.html elasticsearch组合多条件查询实现restful api以及java代码实现 实际开发中 ...

  4. thinkphp整合系列之极验滑动验证码geetest

    给一个央企做官网,登录模块用的thinkphp验证码类.但是2019-6-10到12号,国家要求央企检验官网漏洞,防止黑客攻击,正直贸易战激烈升级时期,所以各事业单位很重视官网安全性,于是乎集团总部就 ...

  5. Spring通过配置类加载实体bean

    以下4个java类都在都一个包下: 1.定义接口 public interface AA { void play(); } 2.定义实体bean //组件注解,表明该类是一个组件 @Component ...

  6. Java错误体系

    1.Java所有的异常错误都继承与Throwable类,只有继承了Throwable类,才能在异常传递体系中进行. 2.Throwable下有两个重要的子类,Error和Exception Error ...

  7. helm搭建本地chart仓库及基本操作

    这个步骤,是配合公司的竞赛. 因为公司这次的环境,我们只有namespace权限,而没有整个集群的管理, 而且,公司没有提供统一的helm chart repo, 所以只能自建. 参考URL: htt ...

  8. 【大数据】0002---MongoDB集群自动分离创建新集群

    场景:MongoDB集群运行后,自动产生新的集群 解答:可能没有理解问题,理清思路如下 1.日志分析 2.配置文件检查(日期.版本) 3.网络IP变化 4.github 5.stack overflo ...

  9. matlab-fsolve函数求解多元非线性方程

    记录一下代码,方便下次套用模板 options=optimset('MaxFunEvals',1e4,'MaxIter',1e4); [x,fval,exitflag] = fsolve(@(x) m ...

  10. 【java】ORA-12505, TNS:listener does not currently know of SID given in connect descriptor

    如果是负载均衡,则 jdbc.url=jdbc:oracle:thin:@(description=(address_list= (address=(host=XX.XXX.X.XX) (protoc ...