`

JavaScript之立即执行函数

 
阅读更多
http://blog.csdn.net/qq838419230/article/details/8030078
立即执行函数(Immediate Functions)
立即执行函数模式是一种语法,可以让你的函数在定义后立即被执行,比如:
(function () {  
    alert('watch out!');  
}());  

这种模式本质上就是函数表达式(命名的或者匿名的),在创建后立即执行;
立即执行函数(immediate function)术语不是在ECMAScript标准中定义的,但它很短有助于描述和讨论模式;

这种模式有一些几部分组成:
使用函数表达式定义一个函数(函数声明不能起作用)
在结尾加上一对括号,让函数立即被执行
将整个函数包裹在一对括号中(只有在你不将函数赋值给一个变量的时候才需要)
下面这种可选的语法形式也是很常见的(注意结尾的一对括号),但JSLint趋向于第一种:
(function () {  
    alert('watch out!');  
})();  


这种模式是非常有用的,因为它为你初始化代码提供了一个作用域的沙箱;
考虑一下下面这种常见的场景:
你的代码在页面代码加载完成之后,不得不执行一些设置工作,比如附加时间处理器,创建对象等等,
所有的这些工作只需要执行一次,所以没有理由创建一个可复用的命名的函数,
但这些代码也需要一些临时的变量,但初始化过程结束后,就再也不会被用到了,
所以将这些变量作为全局变量不是个好主意,所以我们需要立即执行函数——去将我们所有的代码包裹在它的局部作用域中,不会让任何变量泄露成全局变量;
(function() {  
    var days = ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],  
    today = new Date(),  
    msg = 'Today is ' + days[today.getDay()] + ', ' + today.getDate();  
    alert(msg);  
} ()); // "Today is Fri, 13"  

如果代码没有被包裹在立即执行函数中,那么局部变量days,today和msg都将成为全局变量,初始化代码的遗留产物。

立即执行函数的参数(Parameters of an Immediate Function)
你也可以给立即执行函数传递参数,就像下面的例子一样:
// prints:  
// I met Joe Black on Fri Aug 13 2010 23:26:59 GMT-0800 (PST)  
(function(who, when) {  
    console.log("I met " + who + " on " + when);  
} ("Joe Black", new Date()));  

通常,全局变量被作为一个参数传递给立即执行参数,这样它在函数内部不使用window也可以被访问到:这种方式可以让代码在环境(除了浏览器)中更加通用:
(function (global) {  
// access the global object via `global`  
}(this));  

记住:通常你不应该给立即执行函数传递太多的函数,因为它很快会成为一个负担——为了理解代码是如何工作的,你不得不经常上下滚动源代码。

立即执行函数的返回值(Returned Values from Immediate Functions)
就像其它任何函数一样,一个立即执行函数也能返回值并且可以复制给其它变量:
var result = (function () {  
    return 2 + 2;  
}());  

另外一种实现相同的功能的方法是省略包裹函数的括号,因为当你将立即执行函数的返回值赋值给一个变量时它们不是必需的;
var result = function () {  
    return 2 + 2;  
}();  

这种语法是非常简单的,但它可能看起来有点令人误导;
如果没有注意到函数结束的括号,一些人可能就会认为result指向一个函数;
实际上result指向立即执行函数的返回值,在这种情况下是数字 4 。

还有另一种语法可以实现相同的功能:
var result = (function () {  
    return 2 + 2;  
})();  


在前面的例子中返回一个基本类型的整数作为立即执行函数的返回值;
但是除了基本类型值,立即执行函数也能返回任何类型的值,包括其它的函数;
那么,你可以利用立即执行函数的作用域为返回的内部函数私下里存储一些数据。

在接下来的例子中,立即执行函数的返回值是一个函数——被赋值给了变量getResult,这个函数简单的返回了res的值,这个值事先被计算并被储存在立即执行函数的闭包中:
var getResult = (function() {  
    var res = 2 + 2;  
    return function() {  
        return res;  
    };  
} ());  

立即执行函数也可以用来定义对象的属性;
假如,你需要定义一个很可能在对象生命周期中都不会改变的属性,但在你定义之前,你需要做一下工作去计算出正确的值;
你可以使用立即执行函数去封装这些工作,并且立即执行函数的返回值将会成为属性的值,下面的代码:
var o = {  
    message: (function() {  
        var who = "me",  
        what = "call";  
        return what + " " + who;  
    } ()),  
    getMsg: function() {  
        return this.message;  
    }  
};  
// usage  
o.getMsg(); // "call me"  
o.message; // "call me"  

在这个例子中,o.message是一个字符串类型的属性,不是一个函数,但它需要一个函数在脚本被载入时被执行并帮忙定义属性。

好处和用法(Benefits and Usage)
立即执行函数模式被广泛使用,它可以帮你封装大量的工作而不会在背后遗留任何全局变量。
你定义的所有变量都会成员立即执行函数的局部变量,所以你不用担心这些临时变量会污染全局空间。

这种模式经常被使用在书签工具(bookmarklets)中,因为书签工具在任何页面上运行并且保持全局命名空间干净是非常必要的;

这种模式也可以让你将独立的功能封装在自包含模块中(self-contained modules)。
假如你的页面是稳定的并且在没有JavaScript情况下能正常工作,然后本着逐步加强的想法,你加入了一些代码加强页面某个方面;
你可以将这些代码封装进一个立即执行函数中,并且确保页面没有它的情况下也能正常工作。
然后你可以添加更多的加强模块,移除它们,单独测试它们,允许用户去禁用它们等等。

你可以使用下面的模板去定义一个函数模块,让我们叫它module1:
// module1 defined in module1.js  
(function () {  
// all the module 1 code ...  
}()); 
分享到:
评论

相关推荐

    JavaScript中立即执行函数实例详解

    ( function(){…} )()和( function (){…} () )是两种javascript立即执行函数的常见写法,最初我以为是一个括号包裹匿名函数,再在后面加个括号调用函数,最后达到函数定义后立即执行的目的,后来发现加括号的原因...

    深化解析JavaScript中的立刻执行函数_.docx

    深化解析JavaScript中的立刻执行函数_.docx

    深入解析JavaScript中的立即执行函数

    立即执行函数模式在JavaScript中可以让你的函数在定义后立即被执行,下面我们就来深入解析JavaScript中的立即执行函数,需要的朋友可以参考下

    深入理解javascript中的立即执行函数(function(){…})()

    ( function(){…} )()和( function (){…} () )是两种javascript立即执行函数的常见写法,最初我以为是一个括号包裹匿名函数,再在后面加个括号调用函数,最后达到函数定义后立即执行的目的,后来发现加括号的原因...

    JavaScript立即执行函数的三种不同写法

    主要介绍了JavaScript立即执行函数的三种不同写法,需要的朋友可以参考下

    【JavaScript源代码】JavaScript函数this指向问题详解.docx

     一、 函数内 this 的指向 1、普通函数2、构造函数3、对象方法4、事件绑定方法5、定时器函数6、立即执行函数 1、普通函数 2、构造函数 3、对象方法 4、事件绑定方法 5、定时器函数 6、立即执行函数 二、...

    深入浅析javascript立即执行函数

    在Javascript中,任何function在执行的时候都会创建一个执行上下文,因为为function声明的变量和function有可能只在该function内部,这个上下文,在调用function的时候,提供了一种简单的方式来创建自由变量或私有子...

    JavaScript闭包和立即执行函数的个人笔记

    闭包和立即执行函数一、闭包二、闭包的作用三、闭包形式四、立即执行函数五、使用环境六、小练习 一、闭包 当a函数已经执行完了,b函数才开始。 原创文章 10获赞 3访问量 453 关注 私信 展开阅读全文 作者:...

    js中的立即执行函数1

    IIFE(立即调用函数表达式)IIFE( 立即调用函数表达式)是一个在定义时就会立即执行的 JavaScript 函数。示例当函数变成立即执行的函数表达式时,

    详解javascript立即执行函数表达式IIFE

    本文主要介绍了javascript立即执行函数表达式IIFE的相关知识。具有很好的参考价值,下面跟着小编一起来看下吧

    JavaScript中的立即执行函数表达式介绍

    主要介绍了JavaScript中的立即执行函数表达式介绍,本文着重讲解了什么是立即调用函数表达式,需要的朋友可以参考下

    深入理解JavaScript系列

    深入理解JavaScript系列(4):立即调用的函数表达式 深入理解JavaScript系列(5):强大的原型和原型链 深入理解JavaScript系列(6):S.O.L.I.D五大原则之单一职责SRP 深入理解JavaScript系列(7):S.O.L.I.D...

    JavaScript自执行函数和jQuery扩展方法详解

    自执行函数是用一对圆括号将匿名函数包起来,加括号(传参)会立即执行。因为函数无名字,实现了作用域的绝对隔离和函数名的冲突问题。基本形式如下: (function () { console.log('do something'); })();

    JS立即执行函数功能与用法分析

    本文实例讲述了JS立即执行函数功能与用法。分享给大家供大家参考,具体如下: 相信大家经常会遇到下面这两种写法: (function(){ ... })() 和 (function(){ ... }()) 关于这样写是什么意思呢?有什么区别呢? 在...

    深入理解JavaScript系列(.chm)

    深入理解JavaScript系列(4):立即调用的函数表达式 深入理解JavaScript系列(5):强大的原型和原型链 深入理解JavaScript系列(6):S O L I D五大原则之单一职责SRP 深入理解JavaScript系列(7):S O L I D...

Global site tag (gtag.js) - Google Analytics