美文网首页
var 与 let 的区别

var 与 let 的区别

作者: shadow123 | 来源:发表于2017-06-26 16:36 被阅读0次

var

var 声明的变量是函数作用域变量。

var a = 1;
var a = 2;
等价于
var a;
var a;
a = 1;
a = 2;

var 声明的变量提到作用域的前方,简称变量提升。

看一个例子

var a = 1;
function foo(){
  alert(a);
  var a = 2;
}
foo.call()

alert(a)打出来的是什么?

我们先做一下转换,先找声明,把声明提升到作用域的前方,再看代码。

var a;
function foo(){
  var a;
  alert(a);
  a = 2;
}
a = 1;
foo.call()

转换后的代码,我们就一目了然了,alert(a)打出来undefined

function f1(){
  if(true){
  }else{
    var a = 1
  }
  alert(a)
}
f1();

跟前面一样,先找声明,把声明提升到作用域的前方,再看代码。

function f1(){
  var a;
  if(true){
  }else{
    a = 1
  }
  alert(a)
}
f1();

此时的alert(a)也是undefined。

for(var i = 0;i < 6;i++){
  setTimeout(function(){
    console.log(i)
  },1000)
}

打印出i的值是什么呢?
先把声明提升上去,再看代码,1s之后for循环早已执行完毕,此时i的值为6,再执行函数,结果console.log(i)就是6个6。

let

let 声明的变量是块级作用域变量。
let 无法重复声明
let 和 for 循环一起使用有奇怪现象
let 声明的变量提升到块级作用域的第一行
实际声明的一行与块级作用域第一行之间的区域,就是该let 变量的TDZ(临时死亡区域)

let a = 1;
let a = 2; 
//Uncaught SyntaxError: Identifier 'a' has already been declared

重复声明会报错

for(let i = 0;i < 6;i++){
  setTimeout(function(){
    console.log(i)
  },1000)
}

打印出i的值是什么?打印出0 1 2 3 4 5,结果跟我们想的一样,但过程却不一样。

变量i是let声明的,当前的i只在本轮循环有效,所以每一次循环的i其实都是一个新的变量

let a = 1;
{
  console.log(a);
  let a = 2;
}

console.log(a)会打出什么呢?

先做转换,再代码。

let a;
a = 1;
{
  let a;
  console.log(a);
  a = 2;
}

转换完,感觉console.log(a)是undefined.再看看let的第五大特性,console.log(a)这行代码就是TDZ(临时死亡区域),所以执行的结果会报错。
先let声明变量,再使用。

相关文章

  • 关于ES6的let命令

    1、let的基本用法以及let和var的区别 (1) let与var一样是用来声明变量的,与var的区别是let所...

  • 20190301 es6学习—let和const命令

    let命令 let与var之间的不同 声明变量的作用域 作用:声明变量 类似var与var的区别:var声明的变量...

  • var、let 和 const 区别的实现原理是什么

    问题 var、let 和 const 区别的实现原理是什么? 区别 首先先说下三者的区别 var与let是可以声明...

  • let 和 const;函数默认参数

    let let 和 var 一样, 也是是用来定义变量的。如 let 与 var 的区别 let 定义的变量的作用...

  • let和const

    let/const(常用) let和var 区别 let,const用于声明变量,用来替代老语法的var关键字,与...

  • let 与 var区别

    变量提升,let没有,var有。 重复声明,表现不同 作用域不同

  • var 与 let 区别

    es6 刚流行那会,我只知道 var 即将退出历史舞台,取而代之的是 let 和 const,却不知道 var 有...

  • 重读 ES6(一)

    一、let 和 const 命令 let 命令 let 与 var 的区别:let 声明的变量只在 let 命令所...

  • let与const

    let用法 ES6新增了let命令,用法与var类似,主要用于声明变量,且逐渐代替var,与var的区别为,其声明...

  • var 与 let 的区别

    var var 声明的变量是函数作用域变量。 var 声明的变量提到作用域的前方,简称变量提升。 看一个例子 al...

网友评论

      本文标题:var 与 let 的区别

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