zoukankan      html  css  js  c++  java
  • js的es6中for循环中let和var区别

     let和var区别:

     1 for(var i=0;i<5;i++){
     2    setTimeout(()=>{
     3         console.log(i);//5个5
     4     },100) 
     5 }
     6 console.log(i);//5
     7 console.log('=============')
     8 
     9 for(let j=0;j<5;j++){
    10    setTimeout(()=>{
    11         console.log(j);//0,1,2,3,4
    12     },100) 
    13 }
    14 console.log(j);//报错 j is not defined

    为什么 用let就可以显示正确结果,而var就不可以呢?
    var是全局作用域,有变量提升的作用,所以在for中定义一个变量,全局可以使用,循环中的每一次给变量i赋值都是给全局变量i赋值。

     let是块级作用域,只能在代码块中起作用,在js中一个{}中的语句我们也称为叫一个代码块,每次循环会产生一个代码块,每个代码块中的都是一个新的变量j;

     es6中不是说let声明变量不能重复声明吗?看下边例子:

    {
        let a=123;
    }
    { let a
    =246; } console.log(a);//a is not defined; { var b=1; } { var b=2; } console.log(b);// 2;

      {}代表一个块,这个时候let声明的变量只在这个块中起作用,而这个块对var声明的变量不起作用。因为var是全局作用域。

    let a=1;
    let a=2;
    //Uncaught SyntaxError: Identifier 'a' has already been declared
    //let不能重复声明
    
    let b=1;
    var b=2;
    
    // Uncaught SyntaxError: Identifier 'a' has already been declared
    //let不能重复声明
    
    
    var c=3;
    var c=4;
    console.log(c)//4;var可以重复声明
  • 相关阅读:
    CF869E The Untended Antiquity 解题报告
    Walk 解题报告
    CF911F Tree Destruction 解题报告
    P4397 [JLOI2014]聪明的燕姿
    洛谷 P2329 [SCOI2005]栅栏 解题报告
    洛谷 P3747 [六省联考2017]相逢是问候 解题报告
    set-erase
    set-empty
    set-empty
    set-end
  • 原文地址:https://www.cnblogs.com/fanfanZhao/p/12179508.html
Copyright © 2011-2022 走看看