对JS闭包的理解
闭包,是JS里很重要的一个概念,也是相对来讲不太容易理解的一个东西,不过即使难理解,我们也要迎难而上啊,嘿嘿,网上有很多文章都在讲闭包,我在看JS设计模式的时候,书里也着重讲了闭包,但是书里官方的的确是不太容易理解,而网上很多高手也对闭包进行了相对容易理解一些的解释,我也参考大家的文章,按自己理解的闭包,做个学习总结~如果有不对的地方,谢谢路过的读者慷慨指出。下面我们不说废话进入正题。
我们这里不着急先说闭包是个什么东西,先说说闭包形成的原因,为什么会出现闭包这个东西。对于计算机语言来讲,最重要的不是计算,而是存储,JS也是一样的,而提到存储,我们就应该想到变量,提到变量,我们要说两个相关概念:作用域和生存周期。
JS的作用域,有全局作用域和函数作用域,如果我们不用关键字var去声明变量,这个变量就是全局变量,而全局变量,在任何位置都能访问,而且永远都会存在,除非我们主动销毁,这样的变量占用内存并且容易造成命名冲突,所以非必要,我们不要这样声明变量。而我们使用var关键字在函数中声明的变量,就是局部变量,这个变量只有在函数内部才能被访问,函数外部访问不到,而且当函数执行的时候,会生成变量,而函数调用结束后,变量也会被销毁。简单来说,就是函数在运行的时候,可以访问到函数内部的变量,也可以访问函数上一层级的变量,但是在函数外面,不能访问函数内部的变量,函数和函数之间,也不能互相访问对方的变量,而且函数里的变量,就只有在运行的时候存在。但有些情况下,我们需要访问函数内部的变量,这样,闭包就产生了。
所以闭包是什么呢?简单来说,闭包就是能够读取其他函数内部变量的函数。我感觉闭包其实就像个小门一样,函数就像一个屋子,屋子里有卧室、厨房、卫生间,本来这个屋子只有一个门可以进去,我们想进卫生间的话,就只能从这个大门进去,然后再进卫生间,而闭包就像个小门一样,在卫生间另开了一个门,我们在整间屋子的外面,想进屋里的卫生间,如果有了小门,我们就不用走大门进去,而是打开小门,直接就进到了卫生间里。闭包其实就是这个小门~
下面我们来段代码帮助理解一下:
function house() {
var a = "手机";
function wc() {
alert("我从卧室里拿了"+a+"上厕所~");
}
wc();
}
house();
看这段代码,我们在house这个函数里声明了一个变量a,用于存放手机,这部手机我们放在屋子里了,假设我们在客厅看电视,突然想上厕所,大家都知道,不拿手机没法上厕所啊,所以我们拿起茶几上的手机进了厕所,这是正常情况下,我们在屋子里,可以上厕所,但是如果我们在屋子外边 怎么办?着急上厕所,屋子锁门了,我们进不去啊!这个时候,我们就像,如果厕所有个小门开着就好了,我们不就可以直接上厕所了吗?还可以顺便拿上客厅的手机~嘿嘿,在js中,我们可以使用闭包来实现这个过程,代码如下:
function house() {
var a = "手机";
function wc() {
alert("我从卧室里拿了"+a+"上厕所~");
}
return wc;
}
var goWc = house();
goWc();
看上面的代码,goWc其实就是我们留的这个小门,而return wc它其实是一个指针,只是指向这个小门,告诉你说这里有条路可以直接进卫生间,但是并没有进入卫生间的这个动作,那我们怎么进卫生间的呢?我们给goWc后面加了个(),就执行了进入卫生间的这个动作了~
对JS闭包的理解的更多相关文章
- JS闭包的理解及常见应用场景
JS闭包的理解及常见应用场景 一.总结 一句话总结: 闭包是指有权访问另一个函数作用域中的变量的函数 1.如何从外部读取函数内部的变量,为什么? 闭包:f2可以读取f1中的变量,只要把f2作为返回值, ...
- 个人对js闭包的理解
闭包算是前端面试的基础题,但我看了很多关于闭包的文章博客,但感觉很多对于闭包的理想还是有分歧的,现在网上对闭包的理解一般是两种: 有些文章认为闭包必须要返回嵌套函数中里面用到外面函数局部变量的方法 ...
- 【闭包】JS闭包深入理解
先看题目代码: 1 2 3 4 5 6 7 8 9 10 11 12 function fun(n,o) { console.log(o) return { fun:function(m){ ...
- 浅谈对Js闭包的理解
理解Js的闭包,首先让我们先看几个概念 执行环境(executive environment)每个函数都有自己的执行环境,匿名函数默认为全局环境. 作用域链(scope chain)子函数继承父函数, ...
- js 闭包原理理解
问题?什么是js(JavaScript)的闭包原理,有什么作用? 一.定义 官方解释:闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分. 很显然 ...
- 从循环添加事件谈起对JS闭包的理解
1.引子 相信很多初学js的人,都遇到这样一种情况:想要给一堆按钮添加各自的事件,比如点击第i个按钮时,弹出i这个值.理所当然地,我们会这样写: var buttons = document.getE ...
- js闭包的理解-目前网上分析的最透彻文章
js的闭包对于大家实际上并不陌生,但是真正敢说自己完全理解的人并不多.笔者在网上看到分析闭包的文章非常多,篇幅用的非常多,但是实际上分析的并不到位,或者根本就是不正确的.我有时候都在想,写这些文章的人 ...
- JS闭包的理解
闭包的两个特点: 1.作为一个函数变量的一个引用 - 当函数返回时,其处于激活状态.2.一个闭包就是当一个函数返回时,一个没有释放资源的栈区. 其实上面两点可以合成一点,就是闭包函数返回时,该函数内部 ...
- JS闭包深入理解(理解篇)
看书的时候很是不明白为啥变量老是五,经过认真思考的出一下理解: function box() { var arr = []; for (var i = 0; i < 5; i++) { ...
随机推荐
- HDU-4825 Xor Sum,字典树好题!
Xor Sum 一遍A了之后大呼一声好(keng)题!debug了两小时~~~~百度之星资格赛,可以. 题意:给你一个n个元素的数组,m次查询,每次输入一个数k要求从数组中找到一个数与k异或值最大,输 ...
- ICMP TYPE CODE
TYPE CODE Description Query Error 0 0 Echo Reply——回显应答(Ping应答) x 3 0 Network Unreachable——网络不可达 ...
- JSF框架整理
JSP体系结构: JSF主要优势之一就是它既是Java web 应用程序的用户界面标准又是严格遵循 模型-视图-控制器(MVC)设计模式的框架. 用户界面代码(视图)和应用程序数据和逻辑(模型)的清晰 ...
- 【Android】页面迁移时先弹出键盘问题解决
android自动弹出软键盘(输入键盘) 在AndroidMainfest.xml内容无法更改情况下,也就是键盘非要弹出情况下,进入此页面时先关闭软键盘不让其弹出 InputMethodManager ...
- POJ 2411 Mondriaan's Dream ——状压DP 插头DP
[题目分析] 用1*2的牌铺满n*m的格子. 刚开始用到动规想写一个n*m*2^m,写了半天才知道会有重复的情况. So Sad. 然后想到数据范围这么小,爆搜好了.于是把每一种状态对应的转移都搜了出 ...
- 使用HttpClient实现对第三方服务器的请求并接受返回数据
/* * 创建日期 2017-4-7 * * TODO 要更改此生成的文件的模板,请转至 * 窗口 - 首选项 - Java - 代码样式 - 代码模板 */ package com.enfo.int ...
- Jerasure库接口简介及性能测试
http://blog.chinaunix.net/uid-20196318-id-3277600.html Jerasure库提供Reed-Solomon和Cauchy Reed-Solomon两种 ...
- 【Hihocoder1034】毁灭者问题(splay,树状数组)
题意: 假设你拥有 n 个魔法单位,他们从左到有站在一行,编号从 1 到 n. 每个单位拥有三项属性: si: 初始法力. mi: 最大法力上限. ri: 每秒中法力回复速度. 现在你操纵一个毁灭者, ...
- MySQL导出数据库、数据库表结构、存储过程及函数【用】
一.导出数据库 我的mysql安装目录是D:\Program Files\MySQL\MySQL Server 5.5\bin\,导出文件预计放在D:\sql\ 在mysql的安装目录执行命令: my ...
- HDU 3001 三进制 状压dp
Travelling Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total ...