翼度科技»论坛 编程开发 JavaScript 查看内容

JS的预解析

5

主题

5

帖子

15

积分

新手上路

Rank: 1

积分
15
JS的预解析是指在代码执行之前,JavaScript引擎会先对代码进行一次扫描,将变量声明和函数声明提升到当前作用域的顶部,以便在代码执行时能够正确地访问这些变量和函数。这个过程也被称为“提升”。
具体来说,在预解析过程中,JavaScript引擎会将函数声明和变量声明提升到当前作用域的顶部,而不管它们实际上在代码中的位置。这意味着,无论变量和函数声明出现在代码的哪个位置,它们在代码执行之前就已经被处理了,可以在代码中任何位置被访问。
需要注意的是,只有函数声明和变量声明才会被提升,而不是变量的赋值操作。如果变量声明和赋值操作同时出现在同一行代码中,只有变量声明会被提升到作用域顶部,而变量的值仍然会在代码执行时赋值。
 
 
 

预解析在JavaScript中的具体表现有以下几点:
1.    函数声明提升  :在预解析阶段,JavaScript引擎会将函数声明(而非函数表达式)提升到作用域顶部。这意味着,在代码中函数声明可以出现在函数调用之后,甚至可以出现在函数内部,但仍然可以被正确识别和调用。注意,  函数声明既提升也定义  。
例如,下面的代码中,函数 foo() 在预解析阶段被提升到了作用域顶部,因此可以在函数 bar() 内部被正确调用:
  1. bar(); // hello
  2. function bar() {
  3.   foo(); // 可以调用函数 foo()
  4.   
  5.   function foo() {
  6.     console.log('hello');
  7.   }
  8. }
复制代码
 

2.    变量声明提升  :在预解析阶段,JavaScript引擎也会将变量声明提升到作用域顶部,但是不会提升变量的赋值操作。这意味着,变量可以在声明之前被使用,但是如果在声明之前进行赋值操作,会得到undefined。
例如,下面的代码中,变量 x 在声明之前被使用,但是在声明之前进行赋值操作会得到undefined:
  1. console.log(x); // undefined
  2. var x = 10;
复制代码
 

3.    函数表达式不提升  :在预解析阶段,JavaScript引擎不会将函数表达式提升到作用域顶部,只会提升变量声明。因此,在使用函数表达式定义的函数之前,必须先定义变量。
例如,下面的代码中,函数 foo() 是通过函数表达式定义的,因此必须先定义变量 foo 才能调用该函数:
  1. foo(); // Uncaught TypeError: foo is not a function
  2. var foo = function() {
  3.   console.log('hello');
  4. };
复制代码
 


JS的预解析还有一些需要注意的细节,包括以下几点:
1.    函数声明和变量声明的作用域  :在预解析阶段,函数声明和变量声明的作用域是整个函数或全局作用域。这意味着,在函数内部声明的函数和变量可以在整个函数内部被访问,而在全局作用域声明的函数和变量可以在整个脚本中被访问。
 
 

2.    函数声明和变量声明的优先级  :在预解析阶段,函数声明的优先级高于变量声明。这意味着,如果同名函数和变量同时声明,函数声明会覆盖变量声明。
例如,下面的代码中,变量 x 和函数 x() 同名,但是在预解析阶段,函数 x() 会覆盖变量 x :
  1. console.log(x); // function x() {...}
  2. var x = 10;
  3. function x() {
  4.   console.log('hello');
  5. }
复制代码
 

3.    非全局作用域的预解析  :在非全局作用域(如函数作用域)中,预解析只会发生在该作用域内。这意味着,在函数内部声明的函数和变量只会被提升到该函数作用域的顶部,而不会影响到其他函数或全局作用域。
例如,下面的代码中,函数 bar() 内部的变量 x 只会在函数作用域内被提升到作用域顶部,而不会影响到全局作用域或其他函数的作用域:
  1. function foo() {
  2.   bar();
  3.   function bar() {
  4.     console.log(x); // undefined
  5.     var x = 10;
  6.   }
  7. }
  8. foo();
复制代码
 


总的来说,预解析是JavaScript中的一个重要概念,可以帮助我们更好地理解变量和函数的作用域和生命周期。了解预解析的规则和特点,可以帮助我们编写更加规范和可读性更好的JavaScript代码。
当然,现在用了let、const和函数式表达式等,可以避免因为变量提升等带来的小麻烦。

来源:https://www.cnblogs.com/ronaldo9ph/p/17392926.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具