美文网首页
JS系列(七):变量提升

JS系列(七):变量提升

作者: 青叶小小 | 来源:发表于2021-04-04 22:25 被阅读0次

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

// 打印结果
// 2
console.log(a);
var a = 2;

// 打印结果
// undefined

两段代码:

  1. 代码1输出结果『超出预期』,通常会认为结果为:undefined,但实际结果却是2;
  2. 代码2输出结果『符合预期』;

Why ?

这就涉及到JS引擎:编译与执行了:

  1. 编译阶段:会将变量声明提升至所在作用域最前面;
  2. 执行阶段:赋值或调用所处位置不变;

注:

  1. 后面会讲到函数的提升;
  2. 变量提升是早期开发人员的一个bug,后来也未修正;

我们来分析上面两段代码:

  1. 编译阶段,将变量声明提升至所在作用域最前面(这里是全局作用域):
var a;
  1. 执行阶段,赋值or函数调用所处位置不变:
a = 2;
console.log(a);

 --------------------------------------------------------
| 所以,实际编译后的代码形式如下:
--------------------------------------------------------
var a;
a = 2;
console.log(a); // 2
  1. 编译阶段,将变量声明提升至所在作用域最前面(这里是全局作用域):
var a;
  1. 执行阶段,赋值or函数调用所处位置不变:
console.log(a);
a = 2;

 --------------------------------------------------------
| 所以,实际编译后的代码形式如下:
--------------------------------------------------------
var a;
console.log(a); // undefined
a = 2;

/**
 * 这里有个细节:
 * 代码中是 var a = 2
 * 但是在编译阶段,将其拆成了两条语句:
 * var a;
 * a = 2;
 */

小测试(写出编译后的代码):

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

 --------------------------------------------------------
| 所以,实际编译后的代码形式如下:
 --------------------------------------------------------
function foo () {
    var a;
    console.log(a); // undefined
    a = 2;
}

相关文章

  • JS系列(七):变量提升

    两段代码: 代码1输出结果『超出预期』,通常会认为结果为:undefined,但实际结果却是2; 代码2输出结果『...

  • 值得一看的文章--面试可能用得到

    js系列 js面试题 : 本文全面考察了: 变量名提升、this作用域链、运算符优先级、全局变量名污染已经对象属性...

  • JS中的提升

    JS中包含两种提升,变量提升和函数提升。 变量提升 变量提升只能是var或者function声明的变量或者函数,l...

  • 浏览器学习笔记-JS执行

    变量提升 变量提升原理浏览器对js是先编译后执行,在编译过程中,js中的变量声明会被提升到代码段落前面。函数声明和...

  • JavaScript 大纲

    js 语法基础 JavaScript 介绍 js 输出 注释 变量,变量声明提升,全局变量,常量 7 大数据类型 ...

  • Javascript 变量执行过程 和 数组 & 对象的区别

    变量提升 JS执行过程1. 先提升(先提升函数,再提升变量,如果名字一样,变量提升会覆盖函数提升)2. 再执行,如...

  • 变量提升和函数提升

    JS不像C语言,C语言是先声明后使用,否则会报错。但JS中,有变量提升现象,可以先使用后声明。 JS存在变量提升,...

  • 前端经典面试题合集(一)

    1.谈谈变量提升 考察点:js基础知识,js执行机制,变量的提升答:执行js代码时,会生成执行环境,在函数中的代码...

  • 变量声明提升

    变量声明提升是JS中一个基础的问题,同时也是对JS词法作用域认识的一个提升。在JS面试题中,关于变量声明提升的问题...

  • JS变量提升

    废话不多说,直接看以下例子,代码地址: 函数声明和函数表达式 很明显,这个大家都知道这个答案,就是很常见的作用域提...

网友评论

      本文标题:JS系列(七):变量提升

      本文链接:https://www.haomeiwen.com/subject/qmhrkltx.html