JS中作用域有:全局作用域、函数作用域。没有块作用域的概念。ECMAScript 6(简称ES6)中新增了块级作用域。
    块作用域由 { } 包括,if语句和for语句里面的{ }也属于块作用域。

    1. <script type="text/javascript">
    2. {
    3. var a = 1;
    4. console.log(a); // 1
    5. }
    6. console.log(a); // 1
    7. // 可见,通过var定义的变量可以跨块作用域访问到。
    8. (function A() {
    9. var b = 2;
    10. console.log(b); // 2
    11. })();
    12. // console.log(b); // 报错,
    13. // 可见,通过var定义的变量不能跨函数作用域访问到
    14. if(true) {
    15. var c = 3;
    16. }
    17. console.log(c); // 3
    18. for(var i = 0; i < 4; i++) {
    19. var d = 5;
    20. };
    21. console.log(i); // 4 (循环结束i已经是4,所以此处i为4)
    22. console.log(d); // 5
    23. // if语句和for语句中用var定义的变量可以在外面访问到,
    24. // 可见,if语句和for语句属于块作用域,不属于函数作用域。
    25. {
    26. var a = 1;
    27. let b = 2;
    28. const c = 3;
    29. {
    30. console.log(a); // 1 子作用域可以访问到父作用域的变量
    31. console.log(b); // 2 子作用域可以访问到父作用域的变量
    32. console.log(c); // 3 子作用域可以访问到父作用域的变量
    33. var aa = 11;
    34. let bb = 22;
    35. const cc = 33;
    36. }
    37. console.log(aa); // 11 // 可以跨块访问到子 块作用域 的变量
    38. // console.log(bb); // 报错 bb is not defined
    39. // console.log(cc); // 报错 cc is not defined
    40. }
    41. </script>