了解javascript中变量及函数的提升

当 JavaScript 运行一个函数时,会进行两个阶段的操作:

  1. 预编译阶段,它会扫描整个函数代码,收集函数中的变量声明,将其存储在内存中。在这个阶段,JavaScript 引擎会将函数中的变量声明提升到函数体的顶部,并给它赋上默认值 undefined。这个过程就是 变量提升(Hoisting)

  2. 执行阶段,逐行执行函数中可执行的语句。

下面是一个变量提升的示例:

console.log(x); // undefined
var x = 1;

在预编译阶段,变量 x 被提升到函数体的顶部,当程序运行到 console.log(x) 时,由于变量 x 虽然已经被提升,但未被赋值,所以输出 undefined

变量提升有一个例外:用 letconst 声明的变量不会被提前声明。这是因为 letconst 声明的变量具有块级作用域。

下面是一个函数提升的示例:

hello();

function hello() {
  console.log('Hello World!');
}

// 输出:Hello World!

在预编译阶段,函数 hello 被提升到函数体的顶部,因此即使在函数声明之前调用函数,也不会出现 ReferenceError。

需要注意的是,对于函数表达式,变量名的提升与函数不同,变量名不会被带到函数体的顶部。在调用函数之前,该变量名不能被访问。

下面是一个函数表达式的示例:

hello();

var hello = function() {
  console.log('Hello World!');
}

// TypeError: hello is not a function

在预编译阶段,变量 hello 被提升到函数体的顶部,但此时它的值为 undefined。当程序运行到 hello() 时,尝试调用一个未定义的变量会抛出 TypeError 异常。

综上所述,了解变量及函数的提升对于理解 JavaScript 中作用域和闭包等概念至关重要。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:了解javascript中变量及函数的提升 - Python技术站

(0)
上一篇 2023年6月8日
下一篇 2023年6月8日

相关文章

  • Egret引擎开发指南之运行项目

    针对“Egret引擎开发指南之运行项目”的完整攻略,我可以提供以下详细讲解: 1. 准备工作 1.1 安装Egret引擎与配置开发环境 首先需要安装Egret引擎及其相关工具,安装方法参考官方文档中的安装Egret章节。同时,还需要配置好开发环境,这同样可以参考官方文档中的使用TypeScript进行开发章节。 1.2 创建一个新项目 在安装好Egret引擎…

    node js 2023年6月8日
    00
  • Node多进程的实现方法

    Node多进程是指在Node.js运行环境中使用多个进程来处理任务,可以充分利用CPU资源,提高程序性能和可靠性。以下是Node多进程的实现方法及示例。 一、使用child_process模块创建子进程 child_process模块是Node.js中用于创建子进程的核心模块,可以使用它来创建单个子进程或者多个子进程。具体实现方法如下: 1.1 使用spaw…

    node js 2023年6月8日
    00
  • Vite + React从零开始搭建一个开源组件库

    下面是详细讲解“Vite + React从零开始搭建一个开源组件库”的完整攻略。 一、前置知识 在学习“Vite + React从零开始搭建一个开源组件库”之前,需要具备以下知识: 基础的HTML、CSS、JavaScript的知识 熟悉React框架及其生态圈 熟悉ES6语法以及模块化编程思想 熟悉npm包管理工具 熟悉Git版本控制工具 二、搭建项目 1…

    node js 2023年6月9日
    00
  • NodeJs+MySQL实现注册登录功能

    总体架构 NodeJs是一种基于事件驱动、非阻塞I/O模型的JavaScript后端运行环境,它提供了众多的系统模块和第三方模块,以及一个强大的包管理工具npm。MySQL是一种流行的关系型数据库管理系统,提供了完善的数据库设计和管理工具,以及一套丰富的SQL语言和API。 注册登录功能的实现,主要涉及以下几个环节: 用户信息的采集和存储; 用户名和密码的加…

    node js 2023年6月8日
    00
  • 谈谈JavaScript异步函数发展历程

    谈谈JavaScript异步函数发展历程 JavaScript的异步函数是现代前端开发中的重要主题之一。本文将介绍JavaScript异步函数发展的历程,并提供两个示例来说明异步函数的使用。 异步函数的发展历程 在过去,JavaScript中异步编程主要依靠回调函数的方式实现。回调函数是一种将代码作为参数传递给另一个函数的方式,以便在之后某个时间调用该函数。…

    node js 2023年6月8日
    00
  • 从Node.js 转到 Go平台

    从Node.js转到Go平台需要掌握以下技能点: 1.了解Go语言的基础语法和特性 2.掌握Go语言的标准库和常用的第三方工具库 3.学习如何使用Go语言的并发模型 4.理解如何优化Go语言应用程序的性能 下面是从Node.js转到Go平台的完整攻略: 1. 学习Go语言的基础语法和特性 了解Go语言的基础语法和特性是学习Go语言的第一步。你需要学习Go语言…

    node js 2023年6月8日
    00
  • nodeJS express路由学习req.body与req.query方法实例详解

    一、准备工作 在学习Node.js Express路由时,我们需要事先安装好Node.js和Express,并学会如何启动和运行一个Node.js Express服务器。 二、路由基本概念 路由是指在Web应用程序中识别特定状态和参数传递的url并且提供相应的响应或页面的过程。在Node.js Express中,路由是由路由模块进行定义和配置。 三、req.…

    node js 2023年6月8日
    00
  • JavaScript Typescript基础使用教程

    JavaScript Typescript基础使用教程 本教程旨在介绍JavaScript和Typescript的基础使用,帮助初学者快速上手。以下是本教程的主要内容: JavaScript基础使用 基本语法 JavaScript是一种脚本语言,最常见的用途是在网页中添加动态交互效果。JavaScript的基本语法与其他编程语言类似,包括变量声明、数据类型、…

    node js 2023年6月8日
    00
合作推广
合作推广
分享本页
返回顶部