序:闭包这个玩意啊~在很多没有代码块的语言中都会出现,已经成为大多程序员入门的一道坎,闭包让很多程序员觉得晦涩(事实上百度一下这个名词,真的说的很晦涩啊亲==|||),我第一次知道闭包这个名词是从《JavaScript权威指南》中读到的,当时还是2015年的3月份,我刚开始看寒假购买的书,前女友说这本书封面上的犀牛丑死了,我说“你懂啥!”==|||

话不多说,经过一番回忆,我想起来闭包这个东西直到分手后的5个月里都没有搞清楚,某一天我在实验室写完了三段js代码对比后,我了悟了这本神书的讲的闭包思想!

先来看下闭包的百度百科,且看(配图):

闭包是可以包含自由(未绑定到特定对象)变量的代码块;这些变量不是在这个代码块内或者任何全局上下文中定义的,而是在定义代码块的环境中定义(局部变量)。“闭包” 一词来源于以下两者的结合:要执行的代码块(由于自由变量被包含在代码块中,这些自由变量以及它们引用的对象没有被释放)和为自由变量提供绑定的计算环境(作用域)。

在 Scala、Scheme、Common Lisp、Smalltalk、Groovy、JavaScript、Ruby、 Python、Go、Lua、objective c、swift 以及Java(Java8及以上)等语言中都能找到对闭包不同程度的支持。

乍一看,百度说的神乎其神,什么代码块,什么局部变量,说白了,我们只要搞清js的代码的一点原理:作用域的释放和存在问题。

闭包(closure)是Javascript语言的一个难点,也是它的特色,很多高级应用都要依靠闭包实现。

闭包有三个特性:

1.函数嵌套函数

2.函数内部可以引用外部的参数和变量

3.参数和变量不会被垃圾回收机制回收

对比下面三段代码:

且看看下面代码:

//全局变量的应用和变化

Var GLOBAL = 1          //全局变量

function change_global(){

    var GLOBAL = 2;             //重新定义了GLOBAL作为局部变量,不加var则变成了引用全局变量

    alert(GLOBAL);

}

change_global();

Alert(GLOBAL);

浏览器显示:先2,后1。

结论:验证了一点,函数改变了局部变量,但没有改变全局变量,但是一旦去掉了局部变量GLOBAL前面的var那么结果就是2,2。函数执行完后,函数的作用域链被销毁,随之局部变量被销毁了!全局变量要等到页面关闭(程序结束)被销毁

如果很熟悉js语法和作用域链的,可以跳过上面的代码,我是为了说下面的代码!

且看下面代码:

//z是个普通的function,执行一次作用域链就被销毁

var function z(t){

    var s=[1,2,3];              //局部变量s

    s.push(t);          //往s数组中添加数字

    return s;

}

z(4);   //执行后销毁这次

z(5);   //执行后销毁这次

alert(z(6));    //执行后销毁这次

浏览器显示:1,2,3,6。

结论:4,5呢?当然是因为前两次执行结束后函数被销毁了,所以最后只有6被添加进去了,充分证明了js执行函数在内存中的原理——执行完就销毁function中的一切!

上面的话不完全对,真的是一切吗?

且看下面代码:

//x这是个闭包函数,结束后会被销毁,但是因为他返回了另一个函数,这个函数调用并返回了局部变量s,所以s不能被摧毁了,必须被保留下来!

//x这是个闭包函数,结束后会被销毁,但是因为他返回了另一个函数,这个函数调用并返回了局部变量s,所以s不能被摧毁了,必须被保留下来!

function x(){

    var s=[1,2,3];              //一样的局部变量s

    return function(t){

        s.push(t);      //一样往s中添加数字

        return s;

    };

}

var y=x();      //闭包赋值给y变量

y(4);

y(5);

alert(y(6));

浏览器显示:1,2,3,4,5,6。

结论:function x()事实上是制作了一个只属于代码块环境的闭包,闭包中的s变量是不会因为这个x执行完成后被销毁,也不会因为返回的函数执行完后被销毁,即使这段代码全部执行完,s仍然保留在内存中,作用域链也仍然存在,知道程序结束(关闭浏览器)!所以注意:滥用闭包会导致内存不足的!

为了更好的说明,销毁与不销毁的问题,我推荐下面这段代码

//全局对象y,当中的变量:程序结束前永远不会销毁

//函数中的局部对象在函数结束后也会像变量一样被销毁的

var y={

    s:[1,2,3],          //对象中的变量

    //对象中的方法(类似于函数)

add:function(t){

        this.s.push(t);

        return this.s;

    }

}

y.add(4);

y.add(5);

alert(y.s);

浏览器显示:1,2,3,4,5,6。

结论:用对象和闭包达到同样的效果,因为对象除非指定销毁,不然会存留在当前程序内存中!

使用闭包有一个优点,也是它的缺点,就是可以把局部变量驻留在内存中,可以避免使用全局变量。全局变量在每个模块都可调用,这势必将是灾难性的。

《JavaScript权威指南》学习——js闭包的更多相关文章

  1. JavaScript 权威指南-学习笔记(一)

    本文所有教程及源码.软件仅为技术研究.不涉及计算机信息系统功能的删除.修改.增加.干扰,更不会影响计算机信息系统的正常运行.不得将代码用于非法用途,如侵立删! ## JavaScript 权威指南-学 ...

  2. JavaScript权威指南学习笔记6

    这两天主要翻看了书中的第18-22章,重点看了第17章:事件化处理,其它几章节主要是翻了下书知道有相关的概念,没有真正理解其中的内容,或者没有考虑究竟如何能把里面的内容应用到实际的项目中.说的讽刺一点 ...

  3. javascript权威指南学习笔记1

    打开这本书,进入到javascript的世界.以前都是看各种视频,感觉什么收获也没有,反而弄得脑袋混乱,希望能够按照这本书的节奏掌握javascript这门语言,为我的前端学习打下基础. 学习前准备: ...

  4. Javascript权威指南学习笔记

    第二章:词法结构 ;function a(){alert(2)};//前面的分号保证正确地语句解析 第三章:类型.值和变量 基本概念: 1.数据类型---能够表示并操作的值的类型叫做数据类型. 2.变 ...

  5. JavaScript权威指南学习笔记4

    今天看了第9.10.11章,感觉收获最大还是正则表达式那章节,不过这些不用太多脑子思考,问题用到了直接查书就可以了,下面分别总结一下: 第9章类和模块:分9节,前面8节都是在讲类相关的知识,最后一节讲 ...

  6. javascript权威指南学习笔记3

    今天看到第四章,记录一下其中的几个点,俗话说:好记性不如烂笔头嘛. 4.9   in运算符和instanceof运算符 in运算符希望它的左操作数是一个字符串或可以转化为字符串,希望它的右操作数是一个 ...

  7. javascript权威指南学习笔记2

    Javascript语言核心(2~12章) 第三章:类型.值.变量 1.数字: overflow(Infinity, -Infinity).underflow(+0,-0) 非数字值:它和任何值都不相 ...

  8. JavaScript权威指南学习笔记5

    下午在杭图回去前看了书中第二部分的13-17章,看的很粗,感觉大部分东西自己已经知道或者平时开发中不会用到,很多章节只是简单的翻了一下,没有仔细思考里面说到的道理,下面对各章节简单的记录下. 第13章 ...

  9. javascript权威指南第6版学习笔记

    javascript权威指南第6版学习笔记 javascript数组.函数是特殊对象 看一点少一点. 3.1.4 hello.js内容是 var x=.3-.2;var y=.2-.1 console ...

随机推荐

  1. BZOJ4403 序列统计—Lucas你好

    绝对是全网写的最详细的一篇题解  题目:序列统计 代码难度:简单 思维难度:提高+-省选 讲下题面:给定三个正整数N.L和R,统计长度在1到N之间,元素大小都在L到R之间的单调不降序列的数量.输出答案 ...

  2. iPhone safari中Document事件不触发的解决方案 [冒泡]

    写了一个下拉菜单,在单击空白地方的时候隐藏. 第一时间就是用$(document).click(function(){   //隐藏代码  }); 各大浏览器都没问题,唯独iPhone上的不会触发事件 ...

  3. SqlCommandBuilder类是如何构建T-Sql语句

    本篇博客默认你看了[DataTable中AcceptChanges()方法的DataRowRowState属性]这篇博客. 在使用SqlCommandBuilder很简单,就是创建一个SqlComma ...

  4. 海量数据集利用Minhash寻找相似的集合【推荐优化】

    MinHash 首先它是一种基于 Jaccard Index 相似度的算法,也是一种 LSH 的降维的方法,应用于大数据集的相似度检索.推荐系统.下边按我的理解介绍下MinHash 问题背景 给出N个 ...

  5. 搜索suggestion

    题目内容 百度搜索框的suggestion,比如输入北京,搜索框下面会以北京为前缀,展示“北京爱情故事”.“北京公交”.“北京医院”等等搜索词.如何设计使得空间和时间复杂度尽量低.   题目分析 在字 ...

  6. 如何写一手漂亮的 Vue

    前几日听到一句生猛与激励并存,可怕与尴尬同在,最无奈也无解的话:"90后,你的中年危机已经杀到".这令我很受触动.显然,这有些夸张了,但就目前这日复一日的庸碌下去,眨眼的功夫,那情 ...

  7. 使用VB6写一个自定义的进度信息框窗口

    一.起因说明 之前有些项目是用Access完成的,当时为了给用户显示一些进度信息,自制了一个进度信息窗体,类似下图所示: 随着项目不断变迁,需要将进度信息按阶段及子进度进行显示,并且出于代码封装的需求 ...

  8. CDIF:基于JSON的SOA软件框架

    通用设备互联框架(CDIF)是一个具备中美知识产权保护的,基于web的连接框架,目前有部分开源实现存放在: GitHub - out4b/cdif: Common device interconnec ...

  9. 老李分享:qtp自动化测试框架赏析-关键字自动化测试框架

    老李分享:qtp自动化测试框架赏析-关键字自动化测试框架   QTP从2005年继winrunner,robot逐渐退出历史舞台之后,占领主流自动化测试工具市场已经10年之久.当初为了提高在自动化测试 ...

  10. c++中enum的用法——枚举类型

    将变量的可取值全部列举出来,写在程序的开头,使用该类型的时候显示地指定取值即可(即对枚举变量进行赋予元素操作,这里之所以叫赋元素操作不叫赋值操作就是为了说明枚举变量是不能直接赋予算数值的). 如: e ...