• 技术文章 >web前端 >前端问答

    es6中引入了什么作用域

    长期闲置长期闲置2022-05-05 15:44:22原创117

    es6中引入了“块级作用域”;es5中只有全局作用域和函数作用域,es6中由一对大括号包裹形成的作用域就是块级作用域,并明确允许在块级作用域中声明函数,函数声明语句的行为类似于let,在块级作用域之外不可引用。

    本教程操作环境:windows10系统、ECMAScript 6.0版、Dell G3电脑。

    es6中引入了什么作用域

    ES6 引入了块级作用域,明确允许在块级作用域之中声明函数。ES6 规定,块级作用域之中,函数声明语句的行为类似于let,在块级作用域之外不可引用。

    ES6标准中,由一对大括号包裹形成的作用域就是块级作用域。

    ES5 规定,函数只能在顶层作用域和函数作用域之中声明,不能在块级作用域声明。

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

    (1)内层变量可能会覆盖外层变量。

        var tmp = new Date();
        function f() {
            console.log(tmp);
            if (false) {
                var tmp = 'hello world';
            }
        }
        f();//undefined

    (2)用来计数的循环变量泄露为全局变量

        var s = 'hello';
        for (var i = 0; i < s.length; i++) {
            console.log(s[i]);//h e l l o
        }
        console.log(i);//5

    变量i只用来控制循环,但是循环结束后,它并没有消失,泄露成了全局变量。

    示例如下:

    // 浏览器的 ES6 环境
    function f() { console.log('I am outside!'); }
    (function () {
      if (false) {
        // 重复声明一次函数f
        function f() { console.log('I am inside!'); }
      }
      f();
    }());
    // Uncaught TypeError: f is not a function

    在ES6标准中,在块级作用域中声明函数,会将函数声明当做由var声明的变量,提升到块级作用域顶部,只将函数当做变量进行变量名声明,并不会声明函数体,上述代码相当于:

    // 浏览器的 ES6 环境
    function f() { console.log('I am outside!'); }
    (function () {
      var f = undefined;
      if (false) {
        function f() { console.log('I am inside!'); }
      }
      f();
    }());
    // Uncaught TypeError: f is not a function

    【相关推荐:javascript视频教程web前端

    以上就是es6中引入了什么作用域的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:ES6
    上一篇:es6数组怎么修改每个元素 下一篇:es6数组怎么求平均数
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【腾讯云】年中优惠,「专享618元」优惠券!• es6中遍历跟迭代的区别是什么• es6怎么去掉字符串的空格• ES6怎么将伪数组转换成数组• 为什么要将es6转为es5• es6中assign的用法是什么
    1/1

    PHP中文网