美文网首页
第一部分 第3章 函数作用域和块作用域

第一部分 第3章 函数作用域和块作用域

作者: 酥枫 | 来源:发表于2018-10-14 13:01 被阅读0次

函数作用域

  • 函数作用域可以将内部的变量和函数定义隐藏起来

    function foo(/*参数*/){
        //...
    }
    foo(/*参数*/);
    

    但是foo会污染所在作用域,解决这个问题可以通过IIFE(立即执行函数)来解决:

    (function foo(/*参数*/){
        //...
    })(/*参数*/);
    //或者
    
    (function foo(/*参数*/){
        //...
    }(/*参数*/));
    

    这样外部无法访问foo这个函数名。当然你可以直接不写函数名,如下面这样:

    (function(/*参数*/){
        //...
    })(/*参数*/);
    

    即匿名函数,但是匿名函数有几个缺点:

    1. 匿名函数在栈追踪里不会显示出有意义的函数名,调试困难。
    2. 匿名函数在引用自身时只能使用已过期的arguments.callee引用,例如在递归中。
      萨达
    3. 可读性变差。

    综上还是建议使用具名函数。

块作用域

JavaScript没有其他编程语言(如java)中的块级作用域(在ES6之前),只有两个withtry-catch中的catch语句块,也可以用上面说的IIFE来模仿块级作用域,ES6中新增了let和const两个关键字,使得JavaScript有了块级作用域。

  • let
    let关键字可以将变量绑定到所在的任意作用域中(通常是{...}内部),换句话说,let为其声明的变量隐式地劫持了所在的块级作用域。

    let a=2;
    console.log(a);//可以正常访问
    
    {
        let a=2;
    }
    console.log(a);//Reference Error
    

    利用上面这一点,显示地声明快作用域是很有用的一个做法,比如可以在涉及闭包时提醒引擎收集不必要的垃圾。

    用let声明的变量不会进行变量声明提升。

  • const
    用const声明的变量同样是块作用域变量,但const声明的变量是固定的常量,之后任何试图修改值的操作都会引起TypeError错误。用const声明的变量不会进行变量声明提升。

相关文章

  • JavaScript 作用域和闭包理解

    作用域: 分为函数作用域,和块级作用域; 函数作用域 函数作用域外面的无法访问函数作用域内部的变量和函数,这样就可...

  • ES6->块级作用域

    块级作用域 为什么需要块级作用域? ES5 只有全局作用域和函数作用域,没有块级作用域,这带来很多不合理的场景。第...

  • 作用域

    标识符的作用域有函数原型作用域、局部作用域(块作用域)、类作用域和 命名空间(namespace) 作用域 函数原...

  • 第七章 块级作用域、私有变量

    模仿块级作用域 私有变量  js没有块级作用域,只有全局作用域和局部作用域(函数作用域),块级作用域是指某一部分代...

  • 一网打尽 JavaScript 的作用域

    JavaScript 的作用域包括:模块作用域,函数作用域,块作用域,词法作用域和全局作用域。 全局作用域 在任何...

  • JavaScript作用域分类

    JavaScript作用域分类全局作用域局部作用域函数作用域块级作用域catchwithlet 和 const 什...

  • JS的作用域

    JS的作用域: 全局作用域、函数作用域、eval 作用域、块级作用域 全局作用域: 函数作用域: 结果截屏: 说...

  • es6基础知识2

    1. 块作用域 作用域指的是变量的作用范围,js本身具有了全局作用域和函数作用域,es6中新增了块作用域。块作用域...

  • 作用域

    词法作用域,动态作用域,全局作用域,局部作用域,函数作用域,块级作用域,有些地方还能看到隐式作用域和显示作用域。 ...

  • ES6学习-块级作用域、let和const

    一、作用域  在以前的ES5中,作用域只有全局作用域和函数作用域,没有块级作用域。 在函数作用域或全局作用域中通过...

网友评论

      本文标题:第一部分 第3章 函数作用域和块作用域

      本文链接:https://www.haomeiwen.com/subject/femzaftx.html