闭包

闭包的概念

  • 闭包的含义就是闭合,简单来说就是一个具有封闭功能的结构
  • 闭包就是具有封闭的对外不公开的,包裹结构或空间

在 js 中的闭包

  • 在 js 中函数可以构成闭包
  • 函数是一个代码结构的封闭结构,具有包裹特性
  • 根据作用域规则, 只允许函数访问外部数据, 外部无法访问函数内部数据
  • 所以说函数具有封闭的, 不公开的特效, 所以可以构成闭包

闭包解决什么问题

  1. 闭包不允许外界访问
  2. 外界间接访问闭包中的数据
    • 函数可以构成闭包, 解决的问题就是函数外访问到函数内部的数据

得到一个数据

    function foo(){
var num = 123;
return num;
}
var result = foo();
console.log(result);
}
  1. 外部可以访问到函数内的数据
  2. 但是数据不能进行二次访问, 如果再试访问函数内部数据需要再次调用函数, 虽然得到的移入是num = 123, 但是实际不是第一次函数调用的那个值

得到一个函数, 通过函数访问数据

  • 在函数内的数据, 不能直接被函数外访问,如果函数内再定义一个函数, 那么函数内部数据可以被函数外访问
    function foo(){
var num = Math.random();
function fn(){
return num;
}
return fn;
}
var f = foo();
// f 可以直接访问这个数据 num
var result1 = f();
var result2 = f();
// 得到结果一致,说明多次访问的是同一个数据

得到的数据可以是对象

    function foo(){
var o = {name : 'Bob'};
return function(){
return o;
}
}
var fn = foo();
var result = fn();

获得多个数据

    function foo(){
var num1 = Math.random();
var num2 = Math.random();
return {
num1 : function(){
return num1;
},
num2 : function(){
return num2;
}
}
}

获得和修改这个数据

    function foo(){
var num = Math.random();
return {
getNum : function(){
return num;
},
setNum : function(value){
num = value;
}
}
}

闭包的基本结构

  1. 通过函数: 写一个函数, 函数内定义一个新函数, 返回新函数, 使用新函数得到函数内的数据
  2. 通过对象: 写一个函数, 函数内顶一个对象, 对象中绑定多个方法, 返回对象, 利用对象内的方法访问函数内中的数据

闭包的基本用法

  1. 带有私有访问数据的对象
    function Person(){
this.name = 'Peter';
// setName('')
}
// 私有数据指的是只有函数内部可以访问的数据,或者对象内部的方法 // 简单的例子,判断孩子是不是老张家的
function createPerson(){
var name = '张全蛋';
return {
getName : function(){
return name;
},
setName : function(value){
// 如果value的第一个字符串是 张 ,就设置
if(value.charAt(0) === '张'){
name = value;
} esle {
//不姓 张 ,就将错误抛出
throw new Error('你不姓张,难道还能姓王?');
}
}
}
}
  1. 带有私有数据的函数
    // 不具有私有数据
var fn = function(){};
function fn(){} // 具有私有数据
var foo = (function(){
// 私有数据
return function(){
// 可以访问私有数据
}
})();

闭包的基本模型

函数模型

function foo(){
// 私有数据
return function(){
// 可以访问上面的私有数据
}
}

对象模型

function foo(){
// 私有数据
return {
method : function(){
// 可以访问的私有数据
}
}
}

闭包的性能问题

  • 函数的执行需要内存, 函数中定义的变量会在函数执行后自动回收
  • 因为是闭包结构, 如果还有变量引用这些数据的话, 这些数据不会被回收
  • 因此在使用闭包的时候,如果不使用这些数据了, 需要将函数赋值为 null
    var foo = (function(){
var num = 123;
return function(){
return num;
}
})();
// 如果不需要foo中的数据, 赋值为 null
foo = null;

JS面向对象之闭包的更多相关文章

  1. 带你一分钟理解闭包--js面向对象编程

    上一篇<简单粗暴地理解js原型链--js面向对象编程>没想到能攒到这么多赞,实属意外.分享是个好事情,尤其是分享自己的学习感悟.所以网上关于原型链.闭包.作用域等文章多如牛毛,很多文章写得 ...

  2. JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法

    相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...

  3. JS面向对象--你真的理解闭包了吗?

    JS中的闭包,可能在实际开发中我们用的很少,但是面试的时候是必问的.所以今儿个总结一下什么是闭包. 首先,我们定义一个变量.会分为两种情况,1是定义在全局中,我们关闭程序的时候变量会从内存中释放.2是 ...

  4. JS面向对象(2) -- this的使用,对象之间的赋值,for...in语句,delete使用,成员方法,json对象的使用,prototype的使用,原型继承与原型链

    相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...

  5. JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式

    相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...

  6. js面向对象的实现(example 二)

    //这个方法和上篇文章(js面向对象的实现(example 一))中的方法类似,但是更为简洁 //通过函数赋值的方式来构造对象 //同样通过闭包的方式来封装对象及内部变量 (function () { ...

  7. js面向对象+一般方法的选项卡

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. Js面向对象编程

    Js面向对象编程 1.     什么是面向对象编程? 我也不说不清楚什么是面向对象,反正就那么回事吧. 编程有时候是一件很快乐的事,写一些小游戏,用编程的方式玩游戏等等 2.     Js如何定义一个 ...

  9. js面向对象之公有、私有、静态属性和方法详解

    现下,javascript大行其道,对于网站开发人员来说,javascript是必需掌据的一门语言,但随着jquery等框架的流行和使用,许多人对于原生javascript缺乏深入的理解,习惯了函数式 ...

随机推荐

  1. 【BZOJ2818】Gcd [莫比乌斯反演]

    Gcd Time Limit: 10 Sec  Memory Limit: 256 MB[Submit][Status][Discuss] Description 给定整数N,求1<=x,y&l ...

  2. 谈pkusc2016的几道数学题

    题面搬来的qwq(忘记出处了 水印应该能表示) [题解] 1. 我们看到这题先想到令(x+y+z)^3 展开得到一坨,稍微减减,得到我们要求证 delta = 3xy^2+3xz^2+3yx^2+3y ...

  3. Linux : 多线程下载工具: axel

    wget 应该是最常用的下载工具了,但是其不支持多线程下载. axel 安装 epel 源有 axel 的二进制包,可以使用 yum 安装. yum install epel-release yum ...

  4. Linux下安装php环境并且配置Nginx支持php-fpm模块[www]

    Linux下安装php环境并且配置Nginx支持php-fpm模块 http://www.cnblogs.com/freeweb/p/5425554.html 5分钟搭建 nginx +php --- ...

  5. zabbix ZBX_NOTSUPPORTED: Timeout while executing a shell script.

    有一个监控一直都是正常的,今天突然收到报警邮件,上服务器查看服务又是正常的,但是报警邮件还是没恢复 监控端进行脚本测试,发现是正常的 到监控端使用zabbix_get -s ip -p 端口  -k ...

  6. WPF中添加一个文本输入框,按Enter回车,执行绑定的Command

    在WPF+WMMV模式中使用键盘和鼠标事件的绑定代码如下: <TextBox x:Name="SearchBox" Text="{Binding SearchTex ...

  7. SFTP获取数据文件

    使用SFTP:客户端从服务端获取数据文件 客户机: 用户:client IP:13.00.00.11 服务端: 用户:server IP:16.00.00.66 1.在客户端的根目录下,执行下面的命令 ...

  8. [设计模式-行为型]状态模式(State)

    一句话 在一个类的对象中维护状态的类的对象 概括

  9. python的算法:二分法查找(2)--bisect模块

    Python 有一个 bisect 模块,用于维护有序列表.bisect 模块实现了一个算法用于插入元素到有序列表.在一些情况下,这比反复排序列表或构造一个大的列表再排序的效率更高.Bisect 是二 ...

  10. 【hdoj_1050】Moving Tables

    题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=1050 题意为: 为了叙述方便,把一个房间里面的桌子移动到另一个房间称为一个移动,给出若干个要求完成的移 ...