ES6 (一) let与const关键字

前言:


(ES6) 新增加了两个重要的 JavaScript 关键字: let const
let可以保证只在自身代码块内有效,这样很大程度上避免了变量重复,加上其本身一些特性,
在以后开发过程中会比一味用var声明香多了(var声明全局变量);
const小糖认为类似于c语言const,声明之后不准改变变量的值,在ES6中,const声明一个只读变量

一、let特性

1、let 只在代码块内有效 
       

 {
            let data = 0;
            console.log('data = '+data);   //输出0
        }
        console.log('data = '+data);       //报错 ReferenceError: a is not defined

 

 

2、let命令不能重复声明 var就可以
       

 {
            let data1 = 0;
            let data1 = 1;    // Identifier 'data1' has already been declared
            var data2 = 0;
            var data2 = 1;
            console.log(data1);  //0
            console.log(data2);  //1
        }

 

 3、let 运用场景,用于计数器的使用
       

 for (var i = 0;i < 10;i++) {
            setTimeout(function(){
                console.log(i);
            })
        }   //输出10个10
        //i 变量在全局范围内有效,所以全局只有一个变量

        for (let j = 0;j < 10;j++) {
            setTimeout(function(){
                console.log(j);
            })
        }   //0~9
        //j变量只在本轮循环中有效 实际上就是每次循环产生一个新的 不同的变量
        

 

 

 

4、不存在变量提升
       

 //   let 不存在变量提升,var 会变量提升
        {
            console.log(a);  //Cannot access 'a' before initialization
            let a = "a";
        }
 
        console.log(b);  //undefined
        var b = "b";
//变量 b 用 var 声明存在变量提升,所以开始运行的时候,
//b 已经存在了,但是还没有赋值,所以会输出 undefined。
//变量 a 用 let 声明不存在变量提升,在声明变量 a 之前,a 不存在,所以会报错。

 

 

 

二、const特性


1、类似于c语言的const,声明之后不准改变变量的值,一旦声明必须初始化,否则会报错

const NUM = "50";

console.log(NUM);   //50

const NUMS;       // SyntaxError: Missing initializer in const declaration

 

 

三、结束语

希望本篇文章可以帮到求知若渴的众多同学吖~
若能帮到 也欢迎
点赞、收藏、关注我,后续也会持续发布新文章,祝大家学有所成!
欢迎各位前端大佬留言讨论指教! 
小糖谢谢各位啦~❤  ❤  ❤  ❤

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值