Content

  1. What is Scope?
  2. Lexical Scope
  3. Function Vs. Block Scope
  4. Hoisting
  5. Scope Closures

Appendix:

  1. Dynamic Scope
  2. Polyfilling Block Scope
  3. Lexical-this
  4. Thank You's



Chapter1: What is Scope?

In fact, the ability to store values and pull values out of variables is what gives a program state.

背后的问题:

变量储存在哪?

当需要用到它们,程序怎样找到它们?

回答:

需要a well-defined set of rules: Scope.

但是Scope在哪里和如何得到设置get set?


Compiler Theory

JS是编译后的语言。

Compilation的几个大步骤:

  1. Tokenizing/Lexing(代币/类型分析): 把a string of characters分解为有意义的小块,被成为tokens。
  2. Parsing: 把tokens转化进一个嵌套元素的tree结构。集体地代表程序的语法结构。
    • tree叫做Abstract Syntax Tree(提取句法树)
    • var a = 2;
      //被分解成:
      /*
      顶层: VariableDeclaration
      子节点 Identifier: a
      子节点 AssignmentExpression: =
        子节点  NumericLiteral: 2
      */
  3. Code-Generation: 把这个AST转化为可执行的代码。(根据不同语言,有区别)。
    • 转化为机器指令,目的是来创建一个变量a, 并储存一个value到a.

当然JS引擎更复杂。编译时间,在许多情况下,仅仅耗时微秒或更少。并立即在编译后执行代码。


Understanding Scope

学习理解Scope,可以比喻成,进程的一场谈话。

var a = '123'

The Cast 全体演员

  • Engine 响应从开始到结束编译,并执行JS程序。
  • Compiler 编译器。处理所有脏活,包括parsing and code-generation.
  • Scope 收集和保存一个名单。名单上包括所有的变量identifiers,并强迫实施一个严格的规则:这些identifiers如何存取到 currently executing code。

Back & Forth

Engine看2个独立的声明。1个是在编译期间,编译器处理。另一个是在执行期间,引擎处理。

首先,编译器Tokening and Lexing,

然后,  Parsing 代码到AST树,

最后,  Code-Generation。(用到Scope和Engine的交互。)

  1. 编译器询问Scope"变量a是否存在于你的list中?"。

    • 如果是,继续;  如果否,编译器要求Scope去声明一个新的变量a
  2. 编译器生产代码用于Engine在后续执行,去处理a = 2。
    1. Engine 跑起来,先询问Scope:你的当前list里面有变量a吗?
    2. 如果有,Engine使用这个变量, assignment.
    3. 如果没有,Engine去其他地方查看(查看嵌套的Scope部分)

总结:

编译器先声明变量,然后Engine在Scope中查询这个变量,如果发现就分配它。

首先Compiler Speak

然后Engine/Scope Conversation

Engine执行代码,是在编译器生产后的第2步,Engine查询变量a是否已被声明。这个查询是咨询Scope。

Engine执行的查询的类型(LHS和RHS),影响查询的结果outcome。

本例子:var a = '123';

Engine将执行一个“Left-hand Side”查询,查询内容是变量a。

还有"Right-hand Side",准确的描述是:非左侧查询。

Side是指分配符号an assignment operation的左右两边。

如: console.log(a); 就是非左侧查询。

其实LHS和RHS只是涉及是否assign的一种称呼。

"who's the target of the assignment (LHS)" and "who's the source of the assignment (RHS)".

(这两个概念有什么用??见后,ES6以后区别不明显了。)

 Engine和Scope的对话:

function foo(a) {
console.log( a ); //
} foo( 2 );

Engine: Scope,我有一个右侧查询, 引用foo,听说过它吗?

Scope: 当然,我有。Compiler在一秒前声明了它。它是函数。给你!

Engine: 太好了,

You Don't Know JS: Scope & Closures (第一章:什么是Scope)的更多相关文章

  1. Node.js学习(第一章:Node.js安装和模块化理解)

    Node.js安装和简单使用 安装方法 简单的安装方式是直接官网下载,然后本地安装即可.官网地址:nodejs.org Windows系统下,选择和系统版本匹配的.msi后缀的安装文件.Mac OS ...

  2. Node.js学习(第一章:Node.js简介)

    Node.js是什么? Node.js 诞生于 2009 年,由 Joyent 的员工 Ryan Dahl 开发而成, 目前官网最新版本已经更新到 12.0.0版本,最新稳定的是10.15.3.Nod ...

  3. You Don't Know JS: Scope & Closures(翻译)

    Chapter 1: What is Scope? 第一章:什么是作用域 One of the most fundamental paradigms of nearly all programming ...

  4. You Don't Know JS: Scope & Closures (第3章: 函数 vs 块作用域)

    第二章,作用域由一系列的bubbles组成.每一个都代表了一个container或bucket,装着被声明的identifiers(variables, functions).这些bubbles相互嵌 ...

  5. You Don't Know JS: Scope & Closures (第2章: Lexical Scope)

    2种主要的models for how scope work. 最普遍的是Lexical Scope. 另一种 Dynamic Scope.(在Appendix a中介绍.和Lexical Scope ...

  6. You Don't Know JS: Scope & Closures (附加:Lexical/dynamic作用域)(附加:Lexical-this)

    JavaScript只有Lexical Scope 模式 Lexical Scope就是在写代码的时候,定义函数的时候创建的作用域! 而动态作用域是在runtime时,函数被调用的地方的作用域! 实际 ...

  7. 【vue.js权威指南】读书笔记(第一章)

    最近在读新书<vue.js权威指南>,一边读,一边把笔记整理下来,方便自己以后温故知新,也希望能把自己的读书心得分享给大家. [第1章:遇见vue.js] vue.js是什么? vue.j ...

  8. 第一章 用three.js创建你的第一个3D场景

    第一章 用three.js创建你的第一个3D场景 到官网下载three.js的源码和示例. 创建HTML框架界面 第一个示例的代码如下: 01-basic-skeleton.html 位于 Learn ...

  9. 【js 笔记】读阮一峰老师 es6 入门笔记 —— 第一章

      鉴于最近用 vuejs 框架开发项目,其中有很多涉及到 es6 语法不太理解所以便认真地读了一下这本书. 地址:http://es6.ruanyifeng.com/#README 第一章:let ...

随机推荐

  1. default activity not found的问题

    莫名其妙的同一个project下的所有modlue全都出现了这个问题,在网上查了一些解决方法,总结一下就是在运行时把default activity改成nothing,这个把活动都搞没了肯定不行.还有 ...

  2. SVM学习笔记5-SMO

    首先拿出最后要求解的问题:$\underset{\alpha}{min}W(\alpha)=\frac{1}{2} \sum_{i,j=1}^{n}y^{(i)}y^{(j)}\alpha_{i}\a ...

  3. Restful framework【第九篇】分页器

    基本使用 分页 -简单分页 page_size = api_settings.PAGE_SIZE :每页显示条数 page_query_param = 'page' :查询的页码数 page_size ...

  4. POP-OOP-SOP-COP-SOA-AOP

    一.面向过程 二.面向对象 三.面向服务 四.补充 五.总结: 英文及缩写: 面向过程:procedure oriented programming POP 面向对象:object oriented ...

  5. OAuth2.0原理与实现

    弄懂了原理流程,才可以搭建出来.更重要的是,可以根据原理流程自定义搭建,甚至可以完全自己实现一套,最后运行效果和原理和这个对得上就成功了,不要总期待标准答案! 首先参考两篇博客: 阮一峰的博客以及张开 ...

  6. p3398 仓鼠找sugar (LCA+讨论)

    分情况讨论,结果是两条路径有公共点时,深度大的LCA在另一条路径上且另一条路径的两个端点至少其中一个的与深度大的LCA的LCA为那个深度大的LCA #include <cstdio> #i ...

  7. SQL Server 常见数据类型介绍

    数据表是由多个列组成,创建表时必须明确每个列的数据类型,以下列举SQL Server常见数据类型的使用规则,方便查阅. 整数类型 int 存储范围是-2,147,483,648到2,147,483,6 ...

  8. [转载]grep查看上下文及简单正则表达式

    转载自:https://www.cnblogs.com/mfryf/p/3336288.html inux grep 显示前后几行的信息2016年03月02日 14:10:58 ChenHui246 ...

  9. Python cmd中输入'pip' 不是内部或外部命令,也不是可运行的程序或批处理文件。

    配置一下环境变量,找到 添加一下Scripts文件夹的路径,如:这是我的路径C:\Users\ck\AppData\Local\Programs\Python\Python36 就是你python的安 ...

  10. 【Django】【三】模型

    [基本数据访问] 1. models.py写模型 2. 数据库迁移 guest> python manage.py makemigrations sign guest> python ma ...