JS面向对象之闭包
闭包
闭包的概念
- 闭包的含义就是闭合,简单来说就是一个具有封闭功能的结构
 - 闭包就是具有封闭的对外不公开的,包裹结构或空间
 
在 js 中的闭包
- 在 js 中函数可以构成闭包
 - 函数是一个代码结构的封闭结构,具有包裹特性
 - 根据作用域规则, 只允许函数访问外部数据, 外部无法访问函数内部数据
 - 所以说函数具有封闭的, 不公开的特效, 所以可以构成闭包
 
闭包解决什么问题
- 闭包不允许外界访问
 - 外界间接访问闭包中的数据
- 函数可以构成闭包, 解决的问题就是函数外访问到函数内部的数据
 
 
得到一个数据
    function foo(){
        var num = 123;
        return num;
    }
    var result = foo();
    console.log(result);
}
- 外部可以访问到函数内的数据
 - 但是数据不能进行二次访问, 如果再试访问函数内部数据需要再次调用函数, 虽然得到的移入是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;
            }
        }
    }
闭包的基本结构
- 通过函数: 写一个函数, 函数内定义一个新函数, 返回新函数, 使用新函数得到函数内的数据
 - 通过对象: 写一个函数, 函数内顶一个对象, 对象中绑定多个方法, 返回对象, 利用对象内的方法访问函数内中的数据
 
闭包的基本用法
- 带有私有访问数据的对象
 
    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('你不姓张,难道还能姓王?');
                }
            }
        }
    }
- 带有私有数据的函数
 
    // 不具有私有数据
    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面向对象之闭包的更多相关文章
- 带你一分钟理解闭包--js面向对象编程
		
上一篇<简单粗暴地理解js原型链--js面向对象编程>没想到能攒到这么多赞,实属意外.分享是个好事情,尤其是分享自己的学习感悟.所以网上关于原型链.闭包.作用域等文章多如牛毛,很多文章写得 ...
 - JS面向对象(3) -- Object类,静态属性,闭包,私有属性, call和apply的使用,继承的三种实现方法
		
相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...
 - JS面向对象--你真的理解闭包了吗?
		
JS中的闭包,可能在实际开发中我们用的很少,但是面试的时候是必问的.所以今儿个总结一下什么是闭包. 首先,我们定义一个变量.会分为两种情况,1是定义在全局中,我们关闭程序的时候变量会从内存中释放.2是 ...
 - JS面向对象(2) -- this的使用,对象之间的赋值,for...in语句,delete使用,成员方法,json对象的使用,prototype的使用,原型继承与原型链
		
相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...
 - JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式
		
相关链接: JS面向对象(1) -- 简介,入门,系统常用类,自定义类,constructor,typeof,instanceof,对象在内存中的表现形式 JS面向对象(2) -- this的使用,对 ...
 - js面向对象的实现(example 二)
		
//这个方法和上篇文章(js面向对象的实现(example 一))中的方法类似,但是更为简洁 //通过函数赋值的方式来构造对象 //同样通过闭包的方式来封装对象及内部变量 (function () { ...
 - js面向对象+一般方法的选项卡
		
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
 - Js面向对象编程
		
Js面向对象编程 1. 什么是面向对象编程? 我也不说不清楚什么是面向对象,反正就那么回事吧. 编程有时候是一件很快乐的事,写一些小游戏,用编程的方式玩游戏等等 2. Js如何定义一个 ...
 - js面向对象之公有、私有、静态属性和方法详解
		
现下,javascript大行其道,对于网站开发人员来说,javascript是必需掌据的一门语言,但随着jquery等框架的流行和使用,许多人对于原生javascript缺乏深入的理解,习惯了函数式 ...
 
随机推荐
- 完美兼容IE,chrome,ff的设为首页、加入收藏及保存到桌面js代码
			
<script type="text/javascript"> //设为首页 function SetHome(obj,url){ try{ ...
 - 大数问题,通常用JAVA
			
e.g. HDU1002 简单加法 import java.math.BigInteger; import java.util.Scanner; public class Main { public ...
 - IDEA新建时选项没有java class问题
			
解决办法: 点击你的project F4打开project stucture 点击左边的module 点击右边的source后添加src就可以了 添加的src就是源码可以放置的地址
 - POJ3682 King Arthur's Birthday Celebration
			
King Arthur is an narcissist who intends to spare no coins to celebrate his coming K-th birthday. Th ...
 - POJ1286 Necklace of Beads
			
Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 8263 Accepted: 3452 Description Beads ...
 - [bzoj3876][AHOI2014]支线剧情——上下界费用流
			
题目 传送门 题解 建立s和t,然后s向1连下限0上限inf费用0的边,除1外所有节点向t连下限0上限inf费用0的边,对于每条边下限为1上限为inf费用为经过费用,然后我们只有做上下界网络流构出新图 ...
 - hdu 2112 HDU Today (最短路)
			
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2112 题目大意:给出起点和终点,然后算出最短的路. 不过有好多细节要注意: (1)起始点和终止点相等的 ...
 - [Leetcode Week6]Linked List Cycle II
			
Linked List Cycle II 题解 题目来源:https://leetcode.com/problems/linked-list-cycle-ii/description/ Descrip ...
 - swift网址
			
http://www.cocoachina.com/industry/20140613/8818.html Swift -- 中文版两大官方文档汇总发布于:2014-06-13 15:34阅读数:22 ...
 - 【bzoj4282】慎二的随机数列
			
扯几句题外的,最近在看Fate/StayNight,对此人毫无好感…… 每次减一下当前可辨认数,然后随意dp一个LIS,最后记得加回去就好. #include<bits/stdc++.h> ...