执行环境:

// 定义了变量或函数有权访问的其他数据,决定了它们各自的行为
// 每个执行环境都有一个与之关联的变量对象
// 执行环境中定义的所有变量和函数都保存在这个变量中

执行环境与函数:

// 每个函数都有自己的执行环境,当执行流进入一个函数时,函数的环境就会被推入一个环境栈中.
// 而在函数执行之后,栈将其环境弹出,把控制权返回给之前的执行环境

作用域链:

// 当代码在一个环境中执行时,会创建变量对象的一个作用域链.
// 作用域链的用途:保证对执行环境有权访问的所有变量和函数的有序访问
// 作用域链的前端,始终是当前执行的代码所在环境的变量对象
// 如果这个环境是函数,则将其活动对象作为变量对象.
// 活动对象在最开始时只包含一个变量,即arguments对象.
// 作用域链中的下一个变量对象来自包含环境
// 再下一个变量对象来自下一个包含环境
// ...
// 一直延续到全局执行环境!

理解作用域链:

// 当某个函数被调用时,会创建一个执行环境(execution context)及相应的作用域链
// 然后,使用arguments和其他命名参数的值来初始化函数的活动对象
// 在作用域链中,外部函数的活动对象始终处于第二位
// 外部函数的外部函数的活动对象处于第三位
// ...
// 直至作用域链终点的全局执行环境
// 一个例子
function compare(value1, value2) {if (value1 < value2) {return -1;} else if (value1 > value2) {return 1;} else {return 0;}
}
var result = compare(5, 10);// 当在全局环境中调用compare()时,会创建一个活动对象(包含arguments、value1、value2)
// 作用域链中的第一位是compare()的活动对象:arguments、value1、value2
// 作用域链中的第位则是全局变量对象:compare、result

// 后台的每个执行环境都有一个表示变量的对象 --- 变量对象
// 全局环境的变量对象始终存在
// 函数的局部环境变量,只在函数执行的过程中存在.
// 创建compare()函数时,会创建一个预先包含全局变量对象的作用域链,这个作用域链保存在内部的[[Scope]]属性中
// 当调用compare()函数时,会为函数创建一个执行环境,然后通过复制函数的[[Scope]]属性中的对象构建起执行环境的作用域链
// 然后将活动对象(arguments、value1、value2)推入执行环境作用域链的前端.// 一般来讲,当函数执行完毕后,局部活动对象就会被销毁,内存中仅保存全局作用域.

闭包:

// 有权访问另一个函数作用域的变量的函数
// 闭包的常见方式,就是在一个函数内部创建另一个函数
// 闭包的情况有所不同
// 在另一个函数内部定义的函数会将 外部函数的活动对象添加到它的作用域链中
function createComparisonFunction(propertyName) {return function(object1, object2) {var value1 = object1[propertyNmae];var value2 = object2[propertyNmae];if( value1 < value2 ) {return -1;} else if ( value1 > value2 ) {return 1;} else {return 0;}};
}
// 在createComparisonFunction()函数内部定义的匿名函数(function(value1,value2))的作用域链中
// 实际上将会包含外部函数createComparionFunction()的活动对象
// 在匿名函数从createComparionaFuncion()中被返回后,它的作用域链被初始化为包含
// createComparionFunction()函数的活动对象和全局变量对象
// 这样,匿名函数就可以访问在createComparionFunction()中定义的所有变量.
// 更重要的是,createComparionFunction()函数在执行完毕后,其活动对象不会被销毁,因为匿名函数的作用域链仍然在引用这个活动对象


参考《JavaScript高级程序设计》(第3版)P73~P74、 P178~P180

javascript --- 再读作用域和闭包相关推荐

  1. javascript中关于作用域和闭包

    列表项目 前言 学习了javascript已经很久了,关于这个语言中的这两个特性也是早已耳熟能详,但是在实际的使用的过程中或者是遇到相关的问题的时候,还是不能很好的解决. 因此我觉得很有必要深入的学习 ...

  2. javascript(面向对象,作用域,闭包,设计模式等)

    javascript(面向对象,作用域,闭包,设计模式等) 1. 常用js类定义的方法有哪些? 参考答案:主要有构造函数原型和对象创建两种方法.原型法是通用老方法,对象创建是ES5推荐使用的方法.目前 ...

  3. JavaScript函数,作用域以及闭包

    JavaScript函数,作用域以及闭包 1. 函数 (1). 函数定义:函数使用function关键字定义,它可以用在函数定义表达式或者函数声明定义. a. 函数的两种定义方式: * functio ...

  4. JavaScript 函数(作用域以及闭包)

    JavaScript 函数(作用域以及闭包) ・执行环境及作用域 执行环境定义了变量或函数有权访问的其他数据. 每个执行环境都有一个与之关联的变量对象,环境中定义的所有变量或函数都保存在这个对象中, ...

  5. 【你不知道的JavaScript上卷】——作用域与闭包

    原文: [你不知道的JavaScript上卷]--作用域与闭包 JS语言万变不离其宗,其中最常用.最重要的也就是常用的几个大概念.数据类型.作用域.原型链.闭包.this指针.异步,不同的人理解不一样 ...

  6. 【一天时间|JavaScript基础】作用域和闭包

    一天时间系列文章是博主精心整理的面试热点问题和难点问题,吸收了大量的技术博客与面试文章,总结多年的面试经历,带你快速并高效地审视前端面试知识.直击技术痛点,主动出击,精密打击,这才是面试拿到高薪的秘诀 ...

  7. 举例详细说明javascript作用域、闭包原理以及性能问题(转)

    转自:http://www.cnblogs.com/mrsunny/archive/2011/11/03/2233978.html 这可能是每一个jser都曾经为之头疼的却又非常经典的问题,关系到内存 ...

  8. web前端面试高频考点——JavaScript 篇(一)【JS的三座大山 】 原型和原型链、作用域和闭包、异步

    系列文章目录 JavaScript 知识梳理,收录了web前端面试 95%以上 的高频考点,满满的干货.给你做一个高效的知识梳理,为你的面试保驾护航! 内容 参考链接 HTML & CSS 篇 ...

  9. JavaScript 核心概念之作用域和闭包

    相信大家已经阅读了很多关于作用域和闭包文章,我也一样.作用域和闭包是 JavaScript 中的关键概念之一.当我阅读了<高性能的JavaScript>这本书后,我才完全理解这两个概念.所 ...

最新文章

  1. [摘录]第一部分 掌舵领航(3)
  2. Linux中的文件特殊权限
  3. Linux网络协议栈:网卡收包分析
  4. 第一章 初识 MyBatis
  5. 该设备或资源(Web 代理)未设置为接受端口1080上的连接
  6. 扩展二叉树 (根据特殊的前序遍历建树)
  7. mysql res.body_请帮我找一下错吧:body ?php $link=mysql_connect('localhost','root','123') or die (不能连接数据库...
  8. 计算机基础知识思维导图怎么画,怎样在计算机中绘制思维导图的操作过程分享...
  9. 【公式识别神器】Mathpix Snip 安装及其使用教程
  10. 汉字转GB2312编码程序c语言
  11. 计算机主机的税收,税控电脑
  12. 模拟人生畅玩版android,模拟人生畅玩版
  13. elemen点击时,修改走马灯的播放索引
  14. team viewer如何解绑设备
  15. 华为机试题python版节选(基础编程题)
  16. Set? set和Set set的区别?
  17. 93.第十九章 MySQL数据库 -- MySQL安装和基本使用(三)
  18. 金仓监控软件kmonitor安装成功后打开监控界面,监控不到实例
  19. text-align: justify;text-align-last: justify;实现两端对齐
  20. 手把手教你在Photoshop中使用曲线工具

热门文章

  1. Ubuntu15.04如何添加163源
  2. oracle空值判断 =,Oracle,sql server的空值(null)判断
  3. 阿联酋esma认证_阿联酋无人驾驶汽车预计2021年上路
  4. js修改地址栏url_不同寻常的地址栏过渡
  5. vivo应用商店电脑版_VIVO应用商店代理商江湖的那些关系
  6. Unity Fine Prued Tiled Light (FPTL)
  7. zend optimizer php5.5,PHP_PHP5.3以上版本安装ZendOptimizer扩展,现在很多PHP程序都需要ZendOptimi - phpStudy...
  8. python-mysql 基础知识记录
  9. 类模板与运算符重载(一个简单的例子)
  10. Redis failover过程