下面我有两行简单的代码。但我可以向你保证,它要么会让你很困惑(因为你忽略了 JS 的下划线原则),要么安慰你。
但是它已经加载了如下知识概念
我的矛盾声明
就像 var、const 和 let 也提升它们的属性,但它们位于不同的区域。
吊装Def(简单/外行版)
现在是时候深入了解Js如何编译和执行我们的两行代码了
在 JavaScript 中,编译器和引擎处理变量声明和赋值的方式可能有细微差别,尤其是在处理 let 和 var 时。
让我们从编译器和执行的角度来分解给定代码的过程:
name = 'ashu'; let name;
此时我明确表示,当我们编写 javascript 代码时,第一个解析器和编译器会编译我们的代码,然后进入执行阶段。
编译器视角
第一行: name = 'ashu';
编译阶段,
JavaScript 引擎解析代码并创建必要的范围。
作业名称 = 'ashu';
会注明,但在这个阶段,引擎不执行代码;它仅记录对名为 name 的变量的赋值的存在。
如果 name 之前没有声明过,编译器会将其视为对全局变量(全局作用域中的 var name)的赋值,因为 var 声明被提升并可以全局访问。
第二行: 命名;
当编译器遇到let名称时;声明,它承认 name 应该是块作用域的。
编译器将名称放置在临时死区 (TDZ) 其所属范围,
意味着它承认名称的存在,但将其标记为未初始化。
let 声明不以与 var. 相同的方式提升
相反,它在作用域中创建一个绑定,并仅在执行声明时对其进行初始化。
执行视角
第一行: name = 'ashu';
当JavaScript引擎执行赋值name = 'ashu';时,
它检查当前范围内名称是否存在。由于 name 是用 let 声明的,但位于 TDZ(临时死区)中, 在初始化 let 声明之前访问它的任何尝试都将导致 ReferenceError。
因此,此时name在TDZ中,赋值name = 'ashu';导致 ReferenceError.
第二行: 命名;
这一行初始化块作用域内的name变量。
此后,name 不再位于 TDZ 中,可以毫无错误地访问或分配。
现在奖励小费
未声明与未定义与未初始化之间的区别;
undeclare :- 变量尚未声明。
undefined :- 声明变量但未初始化;
未初始化 :- 变量已定义,但其值将在稍后出现。
Ex:- const result =multiplyBy2(5);
直到函数的返回值将分配给结果,直到那时它将处于未初始化区域。
有趣的事实:-
你知道临时死区最初是为 Const 装饰的,但他们在 **Let** 中采用的时间点很晚
参考:-
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3