zoukankan      html  css  js  c++  java
  • 深入理解js的变量提升和函数提升

    一、变量提升

      在ES6之前,JavaScript没有块级作用域(一对花括号{}即为一个块级作用域),只有全局作用域和函数作用域。变量提升即将变量声明提升到它所在作用域的最开始的部分。上个简单的例子如:

    console.log(a); // undefined
    var a= 'hello';
    console.log(hello); // hello
     
    function fn () {
      console.log(b); // undefined
      var b = 'bbb';
      console.log(b); // bbb
    }
    fn();

    之所以会是以上的打印结果,是由于js的变量提升,实际上上面的代码是按照以下来执行的:

    var a; // 变量提升,全局作用域范围内,此时只是声明,并没有赋值
    console.log(a); // undefined
    a= 'aaa'; // 此时才赋值
    console.log(a); // 打印出global
     
    function fn () {
      var b; // 变量提升,函数作用域范围内
      console.log(b);
      b = 'bbb';
      console.log(b);
    }
    fn();
    

      

     注意事项:-------不存在变量提升的变量

    var命令会发生”变量提升“现象,即变量可以在声明之前使用,值为undefined。这种现象多多少少是有些奇怪的,按照一般的逻辑,变量应该在声明语句之后才可以使用。

    为了纠正这种现象,let命令改变了语法行为,它所声明的变量一定要在声明后使用,否则报错。

    // var 的情况
    console.log(foo); // 输出undefined
    var foo = 2;
    
    // let 的情况
    console.log(bar); // 报错ReferenceError
    let bar = 2;
    

      

    const命令声明的常量也是不提升,同样存在暂时性死区,只能在声明的位置后面使用。

    if (true) {
      console.log(MAX); // ReferenceError
      const MAX = 5;
    }
    

      

    二、函数提升

      js中创建函数有两种方式:函数声明式和函数字面量式。只有函数声明才存在函数提升!如:

    console.log(f1); // function f1() {}   
    console.log(f2); // undefined  
    function f1() {}
    var f2 = function() {}
    

      

      只所以会有以上的打印结果,是由于js中的函数提升导致代码实际上是按照以下来执行的:

    function f1() {} // 函数提升,整个代码块提升到文件的最开始<br>     console.log(f1);   
    console.log(f2);   
    var f2 = function() {}
    

      

    结语:基本上就是这样,要熟练掌握的话可以多做些练习,test:

    console.log(f1()); 
    console.log(f2);   
    function f1() {console.log('aa')}
    var f2 = function() {}
    

      

    (function() {
      console.log(a);
      a = 'aaa';
      var a = 'bbb';
      console.log(a);
    })();
  • 相关阅读:
    修复 Visual Studio Error “No exports were found that match the constraint”
    RabbitMQ Config
    Entity Framework Extended Library
    Navisworks API 简单二次开发 (自定义工具条)
    NavisWorks Api 简单使用与Gantt
    SQL SERVER 竖表变成横表
    SQL SERVER 多数据导入
    Devexpress GridControl.Export
    mongo DB for C#
    Devexress XPO xpPageSelector 使用
  • 原文地址:https://www.cnblogs.com/richiewlq/p/8360027.html
Copyright © 2011-2022 走看看