JavaScript学习笔记(十四) 立即执行函数
来源:互联网 发布:罗志祥人气数据 编辑:程序博客网 时间:2024/05/18 00:24
立即执行函数(Immediate Functions)
立即执行函数模式是一种语法,可以让你的函数在定义后立即被执行,比如:
- (function () {
- alert('watch out!');
- }());
立即执行函数(immediate function)术语不是在ECMAScript标准中定义的,但它很短有助于描述和讨论模式;
这种模式有一些几部分组成:
- 使用函数表达式定义一个函数(函数声明不能起作用)
- 在结尾加上一对括号,让函数立即被执行
- 将整个函数包裹在一对括号中(只有在你不将函数赋值给一个变量的时候才需要)
- (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"
立即执行函数的参数(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()));
- (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;
- };
- } ());
假如,你需要定义一个很可能在对象生命周期中都不会改变的属性,但在你定义之前,你需要做一下工作去计算出正确的值;
你可以使用立即执行函数去封装这些工作,并且立即执行函数的返回值将会成为属性的值,下面的代码:
在这个例子中,o.message是一个字符串类型的属性,不是一个函数,但它需要一个函数在脚本被载入时被执行并帮忙定义属性。
- 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"
好处和用法(Benefits and Usage)
立即执行函数模式被广泛使用,它可以帮你封装大量的工作而不会在背后遗留任何全局变量。你定义的所有变量都会成员立即执行函数的局部变量,所以你不用担心这些临时变量会污染全局空间。
这种模式经常被使用在书签工具(bookmarklets)中,因为书签工具在任何页面上运行并且保持全局命名空间干净是非常必要的;
这种模式也可以让你将独立的功能封装在自包含模块中(self-contained modules)。
假如你的页面是稳定的并且在没有JavaScript情况下能正常工作,然后本着逐步加强的想法,你加入了一些代码加强页面某个方面;
你可以将这些代码封装进一个立即执行函数中,并且确保页面没有它的情况下也能正常工作。
然后你可以添加更多的加强模块,移除它们,单独测试它们,允许用户去禁用它们等等。
你可以使用下面的模板去定义一个函数模块,让我们叫它module1:
- // module1 defined in module1.js
- (function () {
- // all the module 1 code ...
- }());
http://blog.csdn.net/qq838419230/article/details/8030078
0 0
- JavaScript学习笔记(十四) 立即执行函数
- JavaScript学习笔记(十四) 立即执行函数
- JavaScript立即执行函数
- Javascript立即执行函数
- javaScript立即执行函数
- JavaScript立即执行函数
- javascript 立即执行函数
- JavaScript立即执行函数
- Javascript立即执行函数
- javascript立即执行函数写法
- javascript立即执行函数写法
- javascript中的立即执行函数
- JavaScript-立即执行函数表达式
- javascript立即执行函数详解
- JavaScript中的立即执行函数
- javascript函数+闭包+立即执行函数
- 详解JavaScript立即执行函数表达式
- javascript模块化:立即执行函数(function(){…})()
- Spring AOP的实现之建立AopProxy代理对象
- 数据仓库数据挖掘——数据仓库中的ETL和元数据
- 第九周项目六穷举法解决组合问题(2)换分币
- HTML5:footer定位(底部+居中)的探讨+div图片居中问题
- 对新手程序员的一些唠叨
- JavaScript学习笔记(十四) 立即执行函数
- Mark一下
- java NIO详解
- android——1
- android学习——2
- android学习3
- Codeforces Round #275 (Div. 2) --A Countexample
- 【JSF】快速入门案例(用户登录界面)
- 第9周项目5程序填充题(1)