JS 用let与var声明变量的区别

1.let定义的变量具有块级作用域,而var定义的变量是全局的

function func() {
        {
            var a = 10;
            let b = 20;
        }
        console.log(a);   //  10
        console.log(b);   //  Uncaught ReferenceError: b is not defined
    }

    func();

使用let定义的变量只能在当前作用域下访问,在块级作用域外则无法访问,而var定义的变量则没有块级作用域特性,因此在块级作用域外也是可以访问得到的

2.在for循环中使用var定义变量会受到循环体外部变量影响,而let不会

function func(){
        var i = 5;
        for(var i=0;i<=10;i++){

        }
        console.log(i);   //  11

        var j = 5;
        for(let j=0;j<=10;j++){

        }
        console.log(j); // 5

    }
    func();

在for循环中,每一次执行的都是一个全新独立的块级作用域,使用let声明的变量在for循环中不会手循环体外部的影响,不会受到变量污染。

3.var有变量提升,而let没有

function func(){
        console.log(a);  // undefined 定义了未赋值
        var a = 10;

        console.log(b);  //  Uncaught ReferenceError: b is not defined 没定义
        let b = 10;
    }
    func();

4..var声明变量会往window对象下压,而let不会

当我们用var声明函数的时候,系统会默认把函数往window这个对象里面压,但由于window对象里面存在着很多自带的属性。

如果碰巧我们声明的函数名跟window下的属性重名了,那么这个函数将把window下的覆盖掉,导致window下的属性无法正常使用。

 var func = function () {
        console.log("haha")
    };
    console.log(window.func());

但如果我们用let声明函数,就不会出现上述问题。用let声明函数的时候是不会往window对象里面添加的,因此也无法通过window.函数名的方式调用函数。

let func = function () {
    console.log("haha")
  };
console.log(func());

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值