JS中的提升机制变量提升函数提升实例详解

 更新时间:2022年09月26日 11:42:48   作者:十七喜欢前端  
这篇文章主要为大家介绍了JS中的提升机制变量提升函数提升实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

正文

对一些计算机语言来说,程序被执行时,对命令的翻译通常是自上而下逐行执行的,这通常被称为代码解释;

对另外一些语言来说,这种翻译是预先进行的,被称为代码编译,这样在程序执行的时候,运行的就是已经编译好的、可执行的计算机指令。

JavaScript通常被认为是解释型的,因为每次执行js源码时都需要进行处理。但这么说也不是完全准确的,我们需要知道,JavaScript引擎实际上是动态编译程序,然后立即执行编译后的代码。而JavaScript中的变量声明和函数提升的直接原因就是编译阶段编译器所做的事。

在提升过程中,虽然声明似乎在程序中被提升了,但实际发生的事情是,函数和变量声明在编译阶段被添加到内存中。

一.变量提升

 就变量和常量而言,关键字 var 被提升,let 和 const 不允许提升。

a = 5;
console.log(a);
var a; // 5

在上面的示例中,在声明变量 a 之前使用它。程序运行并显示输出 5。该程序的作用如下:

var a;
a = 5;
console.log(a); // 5

然而在 JavaScript 中,初始化不会被提升。

console.log(a);//undefined
var a = 5;

上述程序的作用如下:

var a;
console.log(a);
a = 5;

在编译阶段,只有声明被移动到内存中。因此,变量 a 的值是 undefined,因为 a 是在未初始化的情况下打印的。注意:当变量在函数内部使用时,变量仅被提升到函数的顶部。

var a = 4;
function greet() {
    b = 'hello';
    console.log(b); 
    var b;
}
greet(); // hello
console.log(b);//Uncaught ReferenceError: b is not defined

如果变量与 let (const)关键字一起使用,则不会提升该变量。

a = 5;
console.log(a);// error
let a; 

换一种角度说,变量与let(const)关键字一起使用,变量被提升到暂时性死区(TDZ)中,直到程序执行到该变量的let(const)声明语句的时候才从TDZ中被释放。

二.函数提升

由于函数声明和变量声明都会被提升,函数会先被提升,然后才是变量,并且后面的函数声明会覆盖前面的。

代码示例:

foo();
var foo;
function foo(){
	console.log(1);
}
foo = function(){
	console.log(2);
};

最终结果会输出1。因为函数声明会被提升,而函数表达式不会被提升。这段代码可以理解成:

function foo(){
	console.log(1);
}
foo();
foo = function(){
	console.log(2);
};

三.判断顺序

执行函数中的第一行代码时,如何判断该函数的词法作用域中存在哪些变量呢?该变量代表的是什么呢?判断步骤如下:

  • 将参数列表中的参数作为变量标识符存储在作用域中,值为undefined;
  • 将传入的实参对应给相应的参数列表中的标识符赋值;
  • 函数提升;若作用域中有与函数名同名的标识符,则该函数取代该标识符的值;
  • var提升;若作用域中有同名的标识符,则不做任何改变,否则在作用域中添加该标识符,且值为undefined;
  • 执行第一行代码。

四.其他“提升” 

1.作为import结果的声明是“提升的”;

foo();
import { foo } from "foo";

上面这段代码中,foo()是可以运行的,不只是因为import...语句的静态决议在编译过程中确定了foo值是什么,也因为它“提升”了在模块作用域顶层的声明,使它在模块所用位置可用。

以上就是JS中的提升机制变量提升函数提升实例详解的详细内容,更多关于JS 变量提升函数提升的资料请关注脚本之家其它相关文章!

相关文章

  • JavaScript 文件优化全面指南

    JavaScript 文件优化全面指南

    本文将探讨实用的 JavaScript 文件优化技术、如何处理与 JavaScript 文件相关的性能问题以及帮助优化过程的工具,你将获得提升web应用程序速度的相关知识,从而为你的用户提供无缝体验
    2023-12-12
  • 比例尺、缩略图、平移缩放之百度地图添加控件方法

    比例尺、缩略图、平移缩放之百度地图添加控件方法

    这篇文章主要介绍了比例尺、缩略图、平移缩放之百度地图添加控件方法,大家都知道百度地图API中提供了丰富的控件,您还可以通过Control类来实现自定义控件,需要的朋友可以参考下
    2015-08-08
  • 老生常谈javascript的面向对象思想

    老生常谈javascript的面向对象思想

    下面小编就为大家带来一篇老生常谈javascript的面向对象思想。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • javascript数组的定义及操作实例

    javascript数组的定义及操作实例

    在文章里小编给大家整理的是关于javascript数组的定义及操作的相关知识点,需要的朋友们学习下。
    2019-11-11
  • js控制滚动条滚动的两种简单方法

    js控制滚动条滚动的两种简单方法

    这篇文章主要给大家介绍了关于js控制滚动条滚动的两种简单方法,通过JavaScript可以直接控制滚动条的位置,从而达到锁定滚动条的效果,文中通过示例代码介绍的非常详细,需要的朋友可以参考下
    2023-07-07
  • BootStrap表单时间选择器详解

    BootStrap表单时间选择器详解

    这篇文章主要为大家详细介绍了BootStrap表单时间选择器的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • 图解Sublime Text3使用技巧

    图解Sublime Text3使用技巧

    通过本篇文章给大家介绍Sublime Text3使用技巧的相关知识,对sublime text3技巧相关知识感兴趣的朋友一起学习吧
    2015-12-12
  • 基于JavaScript实现图片放大镜功能

    基于JavaScript实现图片放大镜功能

    在一些电商网站上,经常看到有商品图片被放大查看的功能,所以本文将使用前端技术实现一个简单的图片放大镜功能,希望能给大家带来一定的帮助
    2023-06-06
  • JS实现电子时钟入门操作

    JS实现电子时钟入门操作

    这篇文章主要为大家详细介绍了JS实现电子时钟入门操作,实现带有表盘的时钟,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-06-06
  • js如何根据id删除数组中对象

    js如何根据id删除数组中对象

    这篇文章主要介绍了js如何根据id删除数组中对象的问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04

最新评论