码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 块级作用域绑定


    文章目录

      • 1.var声明和变量提升
      • 2.块级声明和临时死区
      • 3.禁止重复声明
      • 4.块级作用域绑定的最佳实践

    1.var声明和变量提升

    无论是在函数作用域亦或是全局作用中使用var声明的变量,都会在预编译阶段被提升到当前作用域的顶部。

    function func(condition) {
    	if(condition){
        var value = "value";
        return value;
      } else {
        //此处可访问到value,但值为undefined
        return null;
      }
      //此处可访问到value,但值为undefined
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    通常在拥有块级作用域的语言中,上述代码块只会在当参数condition的值为true时,value变量才会被创建,且只能在if代码块中被访问到。但在js中,无论condition的值是什么,value变量都会被创建,它再预编译阶段中的实际表现如下:

    function func(condition) {
      var value;
    	if(condition){
        var value = "value";
        return value;
      } else {
        return null;
      }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    2.块级声明和临时死区

    块级声明会将当前声明变量的作用域限制在函数作用域或块级作用域内部,其他非作用区域访问会得到undefined。

    function func(condition) {
    	if(condition){
        let value = "value";
        return value;
      } else {
        //此处访问value会报错
        return null;
      }
      //此处访问value会报错
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    使用let或const的声明的变量会在预编译阶段被加入到临时性死区(TDZ)中,访问临时性死区中的变量会触发引用错误。

    3.禁止重复声明

    使用var声明同名变量时,不会产生任何问题,因为它只是相当于一个赋值操作。

    function(condition) {
    	var value = "value";
      var value = "val";
      //相当于
      var value = "value";
      value = "val";
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    但使用let和const声明变量时,会禁止声明同名变量,抛出变量已定义异常。

    4.块级作用域绑定的最佳实践

    变量定义默认使用const,只有确实需要改变变量的值时使用let。

  • 相关阅读:
    精彩,Excel成为编程语言,国产重量级选手再也坐不住了
    在“企业通讯录”的盲区,融云的边界与分寸
    正则匹配手机、邮箱、密码
    CopyOnWriteArrayList源码分析
    KingbaseES应对表年龄增长过快导致事务回卷
    SAP UI5 Page 控件的构造函数参数讲解
    el-table父子展示不同内容;隐藏内层选择器;列添加不同颜色
    uniapp vue项目把图片路径从data数据传到css(uniapp css变量)
    【Vue】具名插槽
    Docker搭建jenkins环境
  • 原文地址:https://blog.csdn.net/weixin_49971653/article/details/126976691
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号