1. 程式人生 > >ES6入門到進階第一節 定義變數 let const

ES6入門到進階第一節 定義變數 let const

本文是自己總結的,把一些概念寫到程式碼裡了,程式碼可以直接執行。

註釋有點多,執行時候注意一下就好了。

 let 具備塊級作用域 先定義再使用,同一個作用域裡不能重複定義同一個變數,不會覆蓋會報錯
 const 常量 定義好了不能改變,宣告完必須賦值,沒有變數提升
 var 只在函式和全局裡有作用域,如果重複定義會覆蓋,作用域 :全域性作用域和函式(區域性)作用域
 ES6加入塊級(區域性)作用域{}

<!DOCTYPE html>
<html>
<head>
    <title>定義變數</title>
</head>
<body>
    <script type="text/javascript">
        //1.關於定義宣告變數
        for (var i = 0; i < 10; i ++) {

        }
        //alert(i); //彈出10 i為全域性變數 汙染全域性環境

        for (let k = 0; k < 10; k ++) {
            let k = 'abc';  
            console.log(k); //輸出十次“abc”
            //不是重複定義,類似父級作用域,子作用域
        }
        //alert(k);//報錯 k is not defined

        var a = 12;
        function fn() {
            //alert(a);//會彈出undefined 優先用區域性 變數提升  var a; alert(a); a = 5;
            var a = 5;
        }
        fn();

        let d = 12;
        function fnd() {
            //alert(d);//d is not defined 暫時性死區 TDZ
            let d = 5;
        }
        fnd();

        /*
        let 具備塊級作用域 先定義再使用,同一個作用域裡不能重複定義同一個變數,不會覆蓋會報錯
        const 常量 定義好了不能改變,宣告完必須賦值,沒有變數提升
        var 只在函式和全局裡有作用域,如果重複定義會覆蓋
        作用域 :全域性作用域和函式(區域性)作用域
        ES6加入塊級(區域性)作用域{}
         */
        if (true) {
            var b = 1;
            let c = 1;
        }
        //alert(b); 彈出1 因為是全域性
        //alert(c);//報錯 c is not defined
        //經典例子
        //j用var定義都是3,let就彈出相應的數字
        var arr = [];
        for (var j = 0; j < 3; j++) {
            arr[j] = function() {
                console.log(j);
            }
        }
        arr[2]();

        


    </script>
</body>
</html>