JavaScript闭包和模块模式

在JavaScript中一个最广泛使用的设计模式是模块的模式。模块模式使用了JavaScript中的一个很棒的特性-闭包- 用来给你方法中的隐私一些控制这样的第三方应用程序不能访问私有数据或覆盖它。在这篇文章中,我会教你什么是闭包,它是如何工作的,以及如何利用它在你的JavaScript代码中实现模块模式。

什么是闭包?

闭包是JavaScript语言的一种构造。在JavaScript内所有变量都能在全局范围内访问,除非变量在函数内用var关键字声明过。
         
         
variable1 = 1 ; //全局范围
var variable2 = 2 ; // 不在一个函数内: 全局范围
function funcName () {
variable3 = 3 ; // 没用var关键字声明: 全局范围
var variable4 = 4 ; //仅本地访问
}

在一个函数内,你也可以获得全局范围和每个你所在的函数上级范围的访问权限。换句话说,函数内声明变量只能在函数包围范围内访问。
         
         
var globalvar = 1 ; //全局范围
 
function outer () {
var outervar = 2 ; // outer()范围内
 
function inner () {
var innervar = 3 ; // inner()范围内
console . log ( globalvar ); // => 1
console . log ( outervar ); // => 2
console . log ( innervar ); // => 3
}
 
console . log ( globalvar ); // => 1
console . log ( outervar ); // => 2
console . log ( innervar ); // => Reference Error引用错误;
}
 
console . log ( globalvar ); // => 1
console . log ( outervar ); // => Reference Error引用错误
console . log ( innervar ); // => Reference Error引用错误

每一个真正的JavaScript程序员应该知道这一点,除非他不思进取。知道这一点,你可以得出这样的结论,用一种办法来保持你所有代码在全局命名空间外,是正确的。这特别有用,当你不想给任何人在未经许可的情况下有重写你任何代码的机会。你可以通过使用一个匿名函数(不给它命名,没有被赋予一个变量)立即执行自身。这是众所周知的自调用匿名函数(SIAF),虽然它可能是更准确地称为立即调用的函数表达 (IIFE–读做“iffy”) -作者Ben Alman
         
         
( function () {
// 这函数立即执行,内部所有变量都是私有的
}());

紧接着右大括号,是左右括号于是函数将立即执行。围绕整个函数表达式的括号不是运行的代码必需的,但一般用作给其他开发人员的信号,这是一个IIFE,而不是一个标准函数。有些人喜欢在前面加上一个惊叹号(!)或分号(;),而不是用括号包起来。

用闭包的模块模式

知道了闭包是什么,我们就可以使用模块模式创建对象。通过返回一个对象或变量并赋给一个函数外变量,这样我们可以暴露任何希望暴露给外界的,我们可以有公开和私有的方法。
         
         
var Module = ( function () {
// 下面函数是私有的,但可以被公开函数访问
function privateFunc () { };
// 返回一个对象赋予Module
return {
publicFunc : function () {
privateFunc (); // publicFunc可以直接访问privateFunc
}
};
}());

这就是模块模式的本质。您还可以使用参数传入或缩写常用资源的名称:
         
         
var Module = ( function ( $ , w , undefined ) {
// …
// return {…};
}( jQuery , window ));

我传入jQuery和window,被分别缩写为$和w。注意我没有传任何东西作为第三个参数。这样参数undefined将是undefined,所以它完美地工作。有些人这样处理undefined是因为无论如何,它是可编辑的。所以,如果你判断某某是否是undefined,但undefined可能已经改变,你的比较将不起作用。这种技术保证它将按预期工作。

透露模块模式revealing module pattern

透露模块模式是另一种方式来写模块模式,需要更多点代码,但有时更容易理解和阅读。不同于在IIFE中定义所有私有变量并在返回对象中定义公开方法,你把所有方法都写在IIFE中,只是“透露哪些是你想公开在return语句内的。
         
         
var Module = ( function () {
// 现在所有函数直接互访
var privateFunc = function () {
publicFunc1 ();
};
var publicFunc1 = function () {
publicFunc2 ();
};
var publicFunc2 = function () {
privateFunc ();
};
// 返回对象赋予Module
return {
publicFunc1 : publicFunc1 ,
publicFunc2 : publicFunc2
};
}());

对比正常的模块模式,透露模块模式有几个优点:
  1. 所有函数的声明和实现都在同一个地方,从而制造较少的混乱。
  2. 私有函数现在可以访问公开函数,如果他们需要。
  3. 当一个公开函数需要调用另一个公开函数时,他们调用publicFunc2(),而不是用this.publicFunc2(),从而节省了几个字符
透露模块模式的 唯一真正的缺点 ,正如我所说,是你必须写更多的代码,因为你必须先写好函数然后再把它的名字写在return语句内,尽管它最终可能会因为你可以忽略this.部分 而节省你的代码

扩展模块模式

我想谈的最后一件事是使用模块模式扩展已经存在的模块。这很常用,当为 jQuery之类的 库做插件,如下。
1 2 3 4 5 6 7
         
         
var jQuery = ( function ( $ ) {
$ . pluginFunc = function () {
}
return $ ;
}( jQuery ));

此代码是相当灵活的,因为你甚至不需要var jQuery=或接近尾部的return语句。没有它们jQuery仍将可以用这个新方法扩展。实际上返回和赋值整个jQuery对象,可能在性能上有损失,但是,如果你想在扩展jQuery的同时,分配jQuery到一个新的变量名,你只需改变第一行的jQuery为任何你想要的。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GeoPandas是一个开源的Python库,旨在简化地理空间数据的处理和分析。它结合了Pandas和Shapely的能力,为Python用户提供了一个强大而灵活的工具来处理地理空间数据。以下是关于GeoPandas的详细介绍: 一、GeoPandas的基本概念 1. 定义 GeoPandas是建立在Pandas和Shapely之上的一个Python库,用于处理和分析地理空间数据。 它扩展了Pandas的DataFrame和Series数据结构,允许在其存储和操作地理空间几何图形。 2. 核心数据结构 GeoDataFrame:GeoPandas的核心数据结构,是Pandas DataFrame的扩展。它包含一个或多个列,其至少一列是几何列(geometry column),用于存储地理空间几何图形(如点、线、多边形等)。 GeoSeries:GeoPandas的另一个重要数据结构,类似于Pandas的Series,但用于存储几何图形序列。 二、GeoPandas的功能特性 1. 读取和写入多种地理空间数据格式 GeoPandas支持读取和写入多种常见的地理空间数据格式,包括Shapefile、GeoJSON、PostGIS、KML等。这使得用户可以轻松地从各种数据源加载地理空间数据,并将处理后的数据保存为所需的格式。 2. 地理空间几何图形的创建、编辑和分析 GeoPandas允许用户创建、编辑和分析地理空间几何图形,包括点、线、多边形等。它提供了丰富的空间操作函数,如缓冲区分析、交集、并集、差集等,使得用户可以方便地进行地理空间数据分析。 3. 数据可视化 GeoPandas内置了数据可视化功能,可以绘制地理空间数据的地图。用户可以使用matplotlib等库来进一步定制地图的样式和布局。 4. 空间连接和空间索引 GeoPandas支持空间连接操作,可以将两个GeoDataFrame按照空间关系(如相交、包含等)进行连接。此外,它还支持空间索引,可以提高地理空间数据查询的效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值