ES6中let、const、var用法以及区别

var

  • 使用var声明的变量既是顶级变量(顶层对象(window对象)的属性也是全局变量)

通俗来说使用var关键字声明的变量都在window上

  • 使用var声明的变量存在变量提升(提升变量声明)的情况

        console.log(b)  //undefined
        var b =10
        //上面的代码演化成下面的步骤 他不会报错 因为变量声明提升
        var b;
        console.log(b);
        b=10
  • 使用var可以对一个变量进行多次声明,后面的变量会覆盖前面的变量声明

  • 在函数中再次使用var声明这个变量的时候,这个变量就是局部的如果不是用var,那就是全局的

        var d=10
        function fun(){
           var d =20
        }
        fun()
        console.log(d);//10

let

  • 块级作用域

num只能存在于花括号里面

      {
            let num=10
        }
        console.log(num);//报错  num is undefined
  • let不存在变量提升

  • let不允许在相同的作用于下面重复声明

const

  • const 声明的是一个只读的常量,一旦声明,常量的值就不能改变

  • const一旦声明,就必须赋值

  • const 所声明的变量只在let命令所在的代码块中生效

  • const 不存在变量提升

  • const 不允许在相同的作用于下面重复声明

区别

  • 1.1变量提升

var存在变量提升 let和const不存在变量提升

  • 1.2块级作用域

var不存在块级作用域,let和const存在块级作用域,只在所在的代码块生效

  • 1.3重复声明

var 可以重复声明,let和const不允许在同一个作用域中重复声明

  • 1.4修改声明变量

var和let可以修改已经声明的变量,const不可以,一旦声明,必须赋值,并且常量的值不能改变

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值