let&const

1,let支持封闭作用域,声明的变量不会被提升到全局作用域上

//var 不支持封闭作用域(块级作用域),会声明到全局作用域上。ES6以前的只有两个作用域:
//1,函数作用域
//2,全局作用域
---------------------------------------------------
for(var i = 0 ; i <3; i++){
    console.log(i);
}
console.log(i);
console.log(window.i);
//0 1 2 3
---------------------
//以下的方法可以实现块级作用域:
(function(){
    for(var i = 0 ; i <3; i++){
        console.log(i);
    }
})()
//0 1 2 

for (var i = 0; i < 3; i++) {
    (function (i) {
        setTimeout(function () {
            console.log(i);
        }, 1000)
    })(i)
}
//0 1 2 

1. es6提供了新的声明方式,替代了以前的var
2. let和{}配合物会产生一个作用域
3. let支持块级作用域,声明的变量只会声明在当前作用域内
4. let可以解决作用域污染问题和局部作用域问题

for (let i = 0; i < 3; i++) {
    setTimeout(function () {
        console.log(i);//0 1 2
    }, 1000)
}
console.log(i);//报错       let 声明的i变成一个块级作用域,不会声明到全局

2,let不允许在同一个作用域下可以多次声明同一个变量

//var 可以允许在同一个作用域下可以多次声明同一个变量
var a = 1;
function b(){
    var a = 1;
    var a = 2;
}
b();
---------------------------
//let不允许在同一个作用域下可以多次声明同一个变量
var a = 1;
function b(){
    let a = 1;
    let a = 2;
}
b();//报错
---------------------------------------------------
//变量被重复声明,如果用let声明过了,就不要再用var重复声明该变量了。
function b(){
    let a = 1;
    var a = 2;
}
b();//报错   在函数作用域内,已经用var声明a了,再用let就会报错

3,let声明的变量不允许变量声明提升,不会向上查找。

// 域解释问题  变量提升
// let声明的变量不允许变量声明提升
// 暂存死区,如果作用域内,有这样一个变量,那么作用域内就会绑定这个变量,不会向上查找
let a =1;
{
    console.log(a);
    let a = 2;
}//ReferenceError: a is not defined

4,const声明的变量不能被修改

let obj = {'num1' : 20, 'num2' : 30}
const obj1 = obj
const num = obj.num1 
obj.num1 = 40
console.log(obj.num1);//40
console.log(obj1);//{'num1' : 40, 'num2' : 30}
console.log(num);//20
  1. const定义的对象,当对象改变了之后,const定义的值也会跟着改变。

  2. cosnt定义的变量是一个对象的一个属性值,但是当对象属性值改变了以后,const定义的这个值并不会改变。

  3. 在计算机中,常量是放在栈中的,而对象是放在堆中的。 对于对象赋值,const指向的仅仅是他的地址,const仅仅是保证这个地址不改变,至于地址对应的数据,是可以进行改变的。而如果定义一个简单的数据类型(原始值),那这个数据他本身就是存在栈中的,所以不可以改变。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值