关于ES6中let 和 const 命令的用法以及注意事项:

let命令:

基本用法:

  1. let定义:

    用来声明变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效。

    <script>  
    //let代码块内部定义的变量,与var进行对比
    {
        var a =12;
     let b =10
     console.log(a) //-----12
     console.log(b) //-----10
    }
        console.log(a) //-----12
        console.log(b) //----- not undefined
    </script>  
    
  2. for循环很合适使用let命令。在for循环体内有效,在循环体外引用就会报错。

    //let 使用在for循环里面使用不能在外面调用
    for(let i=0;i<=5;i++){
     console.log(i); //------1,2,3,4,5
       }
     console.log(i);  //----- not undefined
    
  3. let在for循环添加事件中最典型的使用方式

    <!DOCTYPE html>
    <html>
     <head>
         <meta charset="utf-8">
         <title></title>
     </head>
     <body>
         <button>1</button>
         <button>2</button>
         <button>3</button>
         <button>4</button>    /*创建六个按钮*/
         <button>5</button>
         <button>6</button>
         <script type="text/javascript">
             // let局部引用
             var btns = document.getElementsByTagName('button');
              for(let i=0;i<btns.length;i++){  //--- 在本行中如果将let更改为var 则点击所有的按钮都会打印数字六,如果使用let,则会根据点击的数字的顺序一次打印,起始数字为0
                 btns[i].onclick =function(){
                     console.log(i)
                 }
             }           
         </script>
     </body>
    </html>
    
  4. / let在for循环作为循环参数的时候其实是两个作用域大括号里面是一个子作用域如果里面再次定义余循环参数相同的变量,则不会产生相互影响

     for(let i=0;i<=3;i++){
            let i ="a";
            console.log(i);  //----4个a
       }
    

不存在变量提升:

  1. let命令改变了语法行为,它所声明的变量一定要在声明后使用,否则报错。

    console.log(a) // ----not defined
    let a = 12;
    

暂时性死区:

  1. ES6 明确规定,如果区块中存在letconst命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错。

    总之,在代码块内,使用let命令声明变量之前,该变量都是不可用的。这在语法上,称为“暂时性死区”(temporal dead zone,简称 TDZ)。

    // 暂时性死区 let 不允许重复定义一个变量
    // 大括号括起来的称之为块作用域 有循环,seitch 结构 if结构
    for(let i =0 ;i<3;i++){
        console.log(i)
        let i = '123';
    }
    
    // 暂时性死区
    function bar (x=y,y=2){
        return[x,y];
    }
    ba=[];
    

不允许重复定义:

  1. 暂时性死区 let 不允许重复定义一个变量

    for(let i =0 ;i<3;i++){
        console.log(i)
        let i = '123';
    }
    

块级作用域:

  1. ES5 只有全局作用域和函数作用域,没有块级作用域,这带来很多不合理的场景。

    第一种场景,内层变量可能会覆盖外层变量。

    if(true){
     function say(){
         console.log(1)
     }
    }
    say();  
    
  2. ES6 引入了块级作用域,明确允许在块级作用域之中声明函数。ES6 规定,块级作用域之中,函数声明语句的行为类似于let,在块级作用域之外不可引用。

    <script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>
     <script type="text/babel">
     // Your ES6 code
     if(true){
         function say(){
             console.log(1)
         }
     }
     say();
     </script>
    

    在这里插入图片描述

    注意:

    为了减轻因此产生的不兼容问题,ES6 在附录 B里面规定,浏览器的实现可以不遵守上面的规定,有自己的行为方式。

    1. 允许在块级作用域内声明函数。
    2. 函数声明类似于var,即会提升到全局作用域或函数作用域的头部。
    3. 同时,函数声明还会提升到所在的块级作用域的头部

浏览器环境:

? Babel 也可以用于浏览器环境,使用@babel/standalone??樘峁┑匿榔靼姹?,将其插入网页。

<script src="https://unpkg.com/@babel/standalone/babel.min.js"></script>
<script type="text/babel">
// Your ES6 code
</script>

? PEPL在线编辑器

const命令:

基本用法:

  1. const定义:

    声明一个只读的常量。一旦声明,常量的值就不能改变。const一旦声明变量,就必须立即初始化,不能留到以后赋值

    const PI = 3.1415;
    console.log( PI )  // ---3.1415
    
    PI = 3;     // --- TypeError: Assignment to constant variable.
    
    const foo;   //--- SyntaxError: Missing initializer in const declaration
    //表示,对于const来说,只声明不赋值,就会报错。
    
  2. const的作用域与let命令相同:只在声明所在的块级作用域内有效。实例与上let例子相似

  3. const命令声明的常量也是不提升,同样存在暂时性死区,只能在声明的位置后面使用。

  4. 本质:

    const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址所保存的数据不得改动。对于简单类型的数据(数值、字符串、布尔值),值就保存在变量指向的那个内存地址,因此等同于常量。但对于复合类型的数据(主要是对象和数组),变量指向的内存地址,保存的只是一个指向实际数据的指针,const只能保证这个指针是固定的(即总是指向另一个固定的地址),至于它指向的数据结构是不是可变的,就完全不能控制了。因此,将一个对象声明为常量必须非常小心。

    const foo = {};
    
    // 为 foo 添加一个属性,可以成功
    foo.prop = 123;
    foo.prop // 123
    
    // 将 foo 指向另一个对象,就会报错
    foo = {}; // TypeError: "foo" is read-only
    

? :常量foo储存的是一个地址,这个地址指向一个对象。不可变的只是这个地址,即不能把foo指向另一个地址,但对象本身是可变的,所以依然可以为其添加新属性。

?著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,128评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,316评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事?!?“怎么了?”我有些...
    开封第一讲书人阅读 159,737评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,283评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,384评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,458评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,467评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,251评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,688评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,980评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,155评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,818评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,492评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,142评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,382评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,020评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,044评论 2 352