首页 > 其他分享 >JS的预解析

JS的预解析

时间:2023-05-12 09:55:55浏览次数:28  
标签:foo 函数 作用域 JS 解析 声明 变量

JS的预解析是指在代码执行之前,JavaScript引擎会先对代码进行一次扫描,将变量声明和函数声明提升到当前作用域的顶部,以便在代码执行时能够正确地访问这些变量和函数。这个过程也被称为“提升”。

具体来说,在预解析过程中,JavaScript引擎会将函数声明和变量声明提升到当前作用域的顶部,而不管它们实际上在代码中的位置。这意味着,无论变量和函数声明出现在代码的哪个位置,它们在代码执行之前就已经被处理了,可以在代码中任何位置被访问。

需要注意的是,只有函数声明和变量声明才会被提升,而不是变量的赋值操作。如果变量声明和赋值操作同时出现在同一行代码中,只有变量声明会被提升到作用域顶部,而变量的值仍然会在代码执行时赋值。

 

 

 


预解析在JavaScript中的具体表现有以下几点:

1. 函数声明提升 :在预解析阶段,JavaScript引擎会将函数声明(而非函数表达式)提升到作用域顶部。这意味着,在代码中函数声明可以出现在函数调用之后,甚至可以出现在函数内部,但仍然可以被正确识别和调用。注意, 函数声明既提升也定义 。

例如,下面的代码中,函数 foo() 在预解析阶段被提升到了作用域顶部,因此可以在函数 bar() 内部被正确调用:

bar(); // hello

function bar() {
  foo(); // 可以调用函数 foo()
  
  function foo() {
    console.log('hello');
  }
}

 


2. 变量声明提升 :在预解析阶段,JavaScript引擎也会将变量声明提升到作用域顶部,但是不会提升变量的赋值操作。这意味着,变量可以在声明之前被使用,但是如果在声明之前进行赋值操作,会得到undefined。

例如,下面的代码中,变量 x 在声明之前被使用,但是在声明之前进行赋值操作会得到undefined:

console.log(x); // undefined

var x = 10;

 


3. 函数表达式不提升 :在预解析阶段,JavaScript引擎不会将函数表达式提升到作用域顶部,只会提升变量声明。因此,在使用函数表达式定义的函数之前,必须先定义变量。

例如,下面的代码中,函数 foo() 是通过函数表达式定义的,因此必须先定义变量 foo 才能调用该函数:

foo(); // Uncaught TypeError: foo is not a function

var foo = function() {
  console.log('hello');
};

 



JS的预解析还有一些需要注意的细节,包括以下几点:

1. 函数声明和变量声明的作用域 :在预解析阶段,函数声明和变量声明的作用域是整个函数或全局作用域。这意味着,在函数内部声明的函数和变量可以在整个函数内部被访问,而在全局作用域声明的函数和变量可以在整个脚本中被访问。

 

 


2. 函数声明和变量声明的优先级 :在预解析阶段,函数声明的优先级高于变量声明。这意味着,如果同名函数和变量同时声明,函数声明会覆盖变量声明。

例如,下面的代码中,变量 x 和函数 x() 同名,但是在预解析阶段,函数 x() 会覆盖变量 x :

console.log(x); // function x() {...}

var x = 10;

function x() {
  console.log('hello');
}

 


3. 非全局作用域的预解析 :在非全局作用域(如函数作用域)中,预解析只会发生在该作用域内。这意味着,在函数内部声明的函数和变量只会被提升到该函数作用域的顶部,而不会影响到其他函数或全局作用域。

例如,下面的代码中,函数 bar() 内部的变量 x 只会在函数作用域内被提升到作用域顶部,而不会影响到全局作用域或其他函数的作用域:

function foo() {
  bar();

  function bar() {
    console.log(x); // undefined
    var x = 10;
  }
}

foo();

 



总的来说,预解析是JavaScript中的一个重要概念,可以帮助我们更好地理解变量和函数的作用域和生命周期。了解预解析的规则和特点,可以帮助我们编写更加规范和可读性更好的JavaScript代码。

当然,现在用了let、const和函数式表达式等,可以避免因为变量提升等带来的小麻烦。

标签:foo,函数,作用域,JS,解析,声明,变量
From: https://www.cnblogs.com/ronaldo9ph/p/17392926.html

相关文章

  • JS 判断电脑是 Win 还是 mac?
    //判断系统类型functionOSnow(){constagent=navigator.userAgent.toLowerCase()constisMac=/macintosh|macosx/i.test(navigator.userAgent)if(agent.indexOf('win32')>=0||agent.indexOf('wow32')>=0){//yourcode......
  • 异步机无感算法解析 提供推导文档,模型,代码…… md500
    异步机无感算法解析提供推导文档,模型,代码……md500ID:442500634075285690......
  • 霍尔Foc算法解析,代码 中颖单片机,3213 提供代码、电路图和pcb
    霍尔Foc算法解析,代码中颖单片机,3213提供代码、电路图和pcb算法对开关霍尔的处理颇有独到之处,是做hallfoc的良好参考……工程中坐标变换是库,算法是开源的,请知悉YID:38100634107899452......
  • vue中解析转义字符
    最近在写一个后台,后台需要展示富文本的内容,按理说使用v-htmll标签就可以,但是当我使用后,却发现页面展示的依旧是html标签,这时我仔细看了一下返回的富文本内容,发现里边包含了展示转义字符<pstyle="line-height:150%"><spanstyle=";font-family:宋体;line-height:150%;font-size:......
  • 如何将bash变量传递给JSON
    我正在尝试编写示例脚本,在其中生成诸如"student-101...student-160"之类的名称。我需要发布JSON数据,当我这样做时,出现JSON解析错误。这是我的脚本:123456789name="student-10"for i in {1..1}do   r_name=$name$i   echo $r_name  curl -i -H 'Au......
  • 浅谈 Node.js
    Node.js是什么?Node.js®是一个开源、跨平台的JavaScript运行时环境。官网:https://nodejs.org/zh-cn更多精彩内容,请微信搜索“前端爱好者“,戳我查看。Node.js≠JavaScriptNode.js中,没有BOM和DOM。Nodejs不是一门语言,只是一个跨平台的JavaScript运行时环境。Node......
  • json在前端的使用
    调用接口后一般传递的都是json格式的数据,这个json格式的数据吗可能会有多层嵌套,如何获取这个最内层的嵌套value值便是关键。而数据解析放在前端便更加的简单,可以像数组一样使用但是需要解决以下问题:1.数据在后端的时候已经是json格式的object,如何异步发送这个json数据到前端(最新......
  • 多线程篇-线程安全-原子性、可见性、有序性解析
    在程序中使用多线程的目的是什么?1、提高效率,增加任务的吞吐量2、提升CPU等资源的利用率,减少CPU的空转多线程的应用在日常开发中很多,带来了很多的便利,让我们以前研究下在多线程场景中要注意问题吧,一般主要从这三个方面考虑1、原子性2、可见性3、有序性如果不能保证原......
  • web游览器的标签页仿 ios mac 苹果的墓碑机制 (js代码)
    背景:本来项目开发系统防挂机功能,在其余游览器中均可以使用。但是呢在苹果的safair游览器中会出现几率失效,最后经过排查发现是苹果的墓碑机制导致。即:此标签页活跃,其他标签页假死。然后就导致防挂机失效了。原理:假如当前游览器中有3个标签页分别是A,B,C,每个标签页都有倒计时。正......
  • JScrollPane
    JScrollPane组件()功能介绍:    当容器的显示区域不足以同时显示所有组件的时候,滚动面版JScrollPane(后省略为JS)可以通过滚动的方式将组件的内容展示出来。使用方法:JS通过将一些组件先添加到JPanel中,再将JPanel添加到JS上,而JTextArea、JList、JTable等组件都没有自......