var let const 区别

简介: var let const 区别

var变量提升 重复声明,顶层(window)属性,全局作用域和函数作用域


let 无提升,不能重复声明,不作为window属性,全局作用域和块级作用域({})暂时性死区(TDZ,同作用域下先声明,再运用)


const 和let类似,声明是必须赋值,不能修改值,可以在不改变引用类型数据的地址时,修改里面的数据,数据可以冻结(object.freeze(数组或对象))


const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址不得改动。对于简单类型的数据(数值、字符串、布尔值),值就保存在变量指向的那个内存地址,因此等同于常量。但对于复合类型的数据(主要是对象和数组),变量指向的内存地址,保存的只是一个指针,const只能保证这个指针是固定的,至于它指向的数据结构是不是可变的,就完全不能控制了。因此,将一个对象声明为常量必须非常小心。


冻结:Object.freeze([0,1,2,3,4,5])


将对象彻底冻结的函数:

var constantize = (obj) => {
  Object.freeze(obj);
  Object.keys(obj).forEach( (key, i) => {
    if ( typeof obj[key] === 'object' ) {
      constantize( obj[key] );
    }
  });
};

例子:

function f() {
            console.log(1)
        }
        (function () {
            //var f会提升到这
            if (true) {
                function f() {
                    console.log(2)
                }
            }
            console.log(f())
        })()
相关文章
|
消息中间件 存储 缓存
Kafka【基础知识 01】消息队列介绍+Kafka架构及核心概念(图片来源于网络)
【2月更文挑战第20天】Kafka【基础知识 01】消息队列介绍+Kafka架构及核心概念(图片来源于网络)
656 2
|
JSON 自然语言处理 数据库
数据库-ElasticSearch入门(索引、文档、查询)
数据库-ElasticSearch入门(索引、文档、查询)
564 0
|
10月前
|
消息中间件 关系型数据库 MySQL
基于 Flink CDC YAML 的 MySQL 到 Kafka 流式数据集成
本教程展示如何使用Flink CDC YAML快速构建从MySQL到Kafka的流式数据集成作业,涵盖整库同步和表结构变更同步。无需编写Java/Scala代码或安装IDE,所有操作在Flink CDC CLI中完成。首先准备Flink Standalone集群和Docker环境(包括MySQL、Kafka和Zookeeper),然后通过配置YAML文件提交任务,实现数据同步。教程还介绍了路由变更、写入多个分区、输出格式设置及上游表名到下游Topic的映射等功能,并提供详细的命令和示例。最后,包含环境清理步骤以确保资源释放。
766 2
基于 Flink CDC YAML 的 MySQL 到 Kafka 流式数据集成
|
存储 机器学习/深度学习 算法
【博士每天一篇文献-综述】基于脑启发的连续学习算法有哪些?附思维导图
这篇博客文章总结了连续学习的分类,包括经典方法(重放、正则化和稀疏化方法)和脑启发方法(突触启发、双系统启发、睡眠启发和模块化启发方法),并讨论了它们在解决灾难性遗忘问题上的优势和局限性。
328 2
|
Linux
Linux导出已经安装好的RPM安装包
Linux导出已经安装好的RPM安装包
1163 1
|
API Android开发 iOS开发
个人微信开发API协议接口
个人微信开发API协议接口
|
缓存 JavaScript Shell
第7期 一文读懂NPX
第7期 一文读懂NPX
1685 0
|
数据采集 监控 API
如何防止恶意调用和攻击对抖音商品详情API的影响?
一、恶意调用的定义和类型 恶意调用是指未经授权或恶意意图地调用某个API,以达到获取不当利益、干扰服务运行或其他非法目的。常见的恶意调用类型包括:
|
关系型数据库 数据库 数据安全/隐私保护
使用脚手架Scaffold-DbContext连接(SqlServer和PostgreSQL)
【代码】使用脚手架Scaffold-DbContext连接(SqlServer和PostgreSQL)
417 0