深入理解JS

68 阅读2分钟

笔记-深入理解JS

01JS的基本概念 browser进程、GPU进程、渲染进程、插进进程、网络进程

单线程;动态、弱类型;面向对象、函数式;解释类语言、JIT;安全、性能差。 参数、结果、副作用、纯函数jQuery、Ramda 原型、继承、封装

JS基本概念-数据类型

数据类型:基础类型(字符串、undefined、数字、null、symbol、bigInt、布尔)和对象类型(数组和函数)

JS的基本概念-作用域

变量的可访问性和可见性

静态作用域,通过它就能够预测代码在执行过程中如何查找标识符。

JS的基本概念-变量提升

Var有变量提升,

Let、const没有变量提升,提前访问会报错

Function函数可以先调用再定义

赋值给变量的函数无法提前调用

02 JS是怎么执行的

当JS引擎解析到可执行代码片段(通常是函数调用)的时候,就会先做一些执行前的准备工作,这个准备工作,就叫做“执行上下文”,也叫执行环境

全局执行上下文:代码开始执行时就会创建,将他压执行栈的栈底,每个生命周期内只有一份

函数执行上下文:当执行一个函数时,这个函数内的代码会被编译,生成变量环境、词法环境等,当函数执行结束的时候该执行环境从栈顶弹出

JS是怎么执行的

词法环境:基于ECMAScript代码的词法嵌套结构来定义标识符和具体变量和函数的关联。一个词法环境由环境记录器和一个可能的引用外部词法环境的空值组成

变量环境:变量环境和词法环境的一个不同就是前者被用来存储函数声明和变量(let和const)绑定,而后者只用来存储var变量绑定

Outer:指向外部变量环境的一个指针