hgq's docs
主页
ES6-阮一峰 (opens new window)
Vue文档 (opens new window)
Axios文档 (opens new window)
Vue Router (opens new window)
Vuex文档 (opens new window)
面试题-Vue (opens new window)
面试题-JS (opens new window)

guoguoqiqi

漫不经心的向往
主页
ES6-阮一峰 (opens new window)
Vue文档 (opens new window)
Axios文档 (opens new window)
Vue Router (opens new window)
Vuex文档 (opens new window)
面试题-Vue (opens new window)
面试题-JS (opens new window)
  • JS数据类型
  • JS数据类型的转换
  • 判断数据类型的方法
  • null和undefined的区别
  • parseInt方法解析
  • promise简答
  • var和let以及const的区别
    • 本地存储的几种方式
    • 闭包是什么
    • 调用new的过程
    • 防抖和节流
    • 简单讲讲异步的理解
    • 简单讲讲原型和原型链
    • 判断变量的数据类型
    • 深浅拷贝
    • 数组去重的方法
    • 说一说JS中的this
    • 作用域和作用域链
    • JS的内置对象
    • JS继承的几种实现方式
    • 谈谈你对this、call、apply和bind的理解
    • 说一说原型、原型链
    • 什么是闭包,为什么使用闭包
    • JS中事件冒泡与捕获
    • 说一说JS的事件模型
    • 常用的遍历数组的方法
    • 如何创建一个Ajax
    • js 延迟加载的方式有哪些
    • 谈谈你对模块化开发的理解
    • js 的几种模块规范
    • ES6 模块与 CommonJS 模块、AMD、CMD 的差异
    • JS的运行机制、单线程、事件循环、宏任务微任务
    • arguments 的对象是什么
    • 简单介绍一下 V8 引擎的垃圾回收机制
    • 哪些操作会造成内存泄漏
    • ES6有哪些新特性
    • 说一说箭头函数
    • 什么是高阶函数
    • 为什么函数被称为一等公民
    • js的深浅拷贝
    • 函数柯里化
    • 说一说new操作符
    • 说一说对Promise的理解
    • Generator函数是什么,有什么作用
    • 说一说async和await
    • instanceof的原理是什么,如何实现
    • js 的节流与防抖
    • 相关面试题集合
    • 如何更好的处理async、await的异常
    • JS的事件委托
    • 浏览器和node中事件循环的区别
    • mouseover 和 mouseenter 的区别
    • ===与Object is的区别
    • 数组去重有哪些方法
    • 页面在浏览器中渲染出来的原理和流程
    • js和css是否会阻塞页面的渲染
    • Set、Map、WeakSet 和 WeakMap 的区别
    • 说一说Promise的实现原理
    • 说一说JS的事件循环
    • == 和 === 与隐式转化
    • 说一说回流(重排)和重绘
    • script标签中添加async或defer的作用与区别
    • 如何中断一个请求
    • 遍历一个对象身上属性的方法有哪些
    • 常用的数组方法(不改变原数组)
    • 常用的数组方法(改变原数组)
    • 常用字符串操作方法
    • 对象身上与原型相关的方法
    • 数组的reduce方法
    • 常用的位运算符有哪些
    • 浮点数运算有误差的问题
    • typeof和instanceof的区别
    • 有关js和css对页面渲染阻塞的问题
    • 说说对闭包的理解
    • DOMContentLoaded方法
    • es6中对象新增的方法
    • es6中数组新增的方法
    • es6中字符串新增的方法
    • es6新增的Reflect
    • 如何判断一个变量是否是数组
    • onload 和 DOMContentLoaded的区别
    • 大文件上传问题
    • 上传、下载和普通请求的区别
    • Javascript
    guoguoqiqi
    2022-02-12

    var和let以及const的区别

    # var、let和const之间的区别

    主要从四点讨论这三者的异同:

    • 作用域规则
    • 重复声明/重复赋值
    • 变量提升(hoisted)
    • 暂时死区(TDZ)

    # 1.var

    • 在全局作用域下使用 var 声明一个变量,默认它是挂载在顶层对象 window 对象下(Node 是 global)
    • 用 var 声明的变量的作用域是它当前的执行上下文,可以是函数也可以是全局
    • 如果赋值给未声明的变量,该变量会被隐式地创建为全局变量(它将成为顶层对象的属性,造成全局环境变量不可控、混乱)
    • 使用var声明的变量存在变量提升的情况
    • 允许多次声明同一变量而不报错,造成代码不容易维护

    # 2.let

    • let 与 var 的写法一致,不同的是它使用的是块作用域
    • 块作用域变量在包含它们的块或 for 循环之外是不能访问的
    • 使用 let 在全局作用域下声明的变量也不是顶层对象的属性
    • 不允许同一块中重复声明
    • let 声明的变量在被声明之前不能被访问(暂时死区(TDZ))

    在 JavaScript 中,当控制流进入它们出现的范围时,所有绑定声明都会被实例化。传统的 var 和 function 声明允许在实际声明之前访问那些绑定,并且其值(value)为 undefined 。这种遗留行为被称为变量提升(hoisting)。当控制流进入它们出现的范围时,let 和 const 声明也会被实例化,但在运行到实际声明之前禁止访问。这称为暂时性死区( Temporal Dead Zone)。TDZ 的存在是为了防止传统提升可能造成的那种错误。

    # 3.const

    • const 声明一个只读的常量。一旦声明,常量的值就不能改变。
    • const声明的变量不得改变值,这意味着,const一旦声明变量,就必须立即初始化,不能留到以后赋值。
    • 注意,这里 const 保证的不是变量的值不得改动,而是变量指向的那个内存地址不得改动,如果是基本类型的话,变量的值就保存在那个内存地址上,也就是常亮,如果是引用类型,它内部的值是可以变更的
    • 只在声明所在的块级作用域内有效
    • 常量也是不提升,同样存在暂时性死区

    # 总结

    1. 作用域规则
    • let/const 声明的变量属于块作用域,只能在其块或子块中可用。而 var 声明的变量的作用域是是全局或者整个封闭函数
    1. 重复声明/重复赋值
    • var 可以重复声明和重复赋值

    • let 仅允许重复赋值,但不能重复声明

    • const 既不可以重复赋值,但不能重复声明

    1. 变量提升(hoisted)
    • var 声明的变量存在变量提升,即可以在变量声明前访问变量,值为undefined

    • let 和 const 不存在变量提升,即它们所声明的变量一定要在声明后使用,否则报错 ReferenceError

    image

    # 参考文章链接

    var、let、const 有什么区别 (opens new window) var、let、const三者之间的区别 (opens new window)

    ← promise简答 本地存储的几种方式→

    最近更新
    01
    vuex数据持久化怎么做
    05-22
    02
    vue的动态路由怎么配置使用
    05-22
    03
    vue权限控制一般怎么做
    05-22
    更多文章>
    Theme by Vdoing | Copyright © 2022-2022 Guoquoqiqi | MIT License
    • 跟随系统
    • 浅色模式
    • 深色模式
    • 阅读模式