正确理解Javascript Closures -- 闭包


声明:本文转载自https://my.oschina.net/u/2510955/blog/1551513,转载目的在于传递更多信息,仅供学习交流之用。如有侵权行为,请联系我,我会及时删除。

闭包是Javascript中最常见的语法和形式之一,闭包可以避免全局污染,模块化编程。

要理解闭包,先要熟悉scope, Javascript的基本概念

0 准备

Scope - 作用域

Javacript中的作用域有两种

  • Global scope
  • Local scope

定义在函数之内的变量处于local scope, 定义在函数之外的变量处于global scope, 函数每调用一次,就新生成一个scope

  • Global scope的生存期为整个应用application
  • Local scope的生存期为所在函数被调用和执行中

Context - 上下文

context和scope不同,scope决定变量的可见性,context则决定了this的值,在同样的scope里

context是可以通过function methods修改的, .apply(), .bind(), .call()

 

Execution Context - 执行上下文

execution context就是execution scope,里面的context和上面讲到context不一样

本文发表于2017年10月16日 18:39
(c)注:本文转载自https://my.oschina.net/u/2510955/blog/1551513,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如有侵权行为,请联系我们,我们会及时删除.

阅读 1737 讨论 0 喜欢 0

抢先体验

扫码体验
趣味小程序
文字表情生成器

闪念胶囊

你要过得好哇,这样我才能恨你啊,你要是过得不好,我都不知道该恨你还是拥抱你啊。

直抵黄龙府,与诸君痛饮尔。

那时陪伴我的人啊,你们如今在何方。

不出意外的话,我们再也不会见了,祝你前程似锦。

这世界真好,吃野东西也要留出这条命来看看

快捷链接
网站地图
提交友链
Copyright © 2016 - 2021 Cion.
All Rights Reserved.
京ICP备2021004668号-1