- 前言
- 关于 ECMASCRIPT 发展史和现状
- ES6 带来的重大特性
- ES2016(ES7)的改进
- ES2017(ES8)带来的重大新特性
- ES2018(ES9)带来的重大新特性
- JavaScript 编码风格指南
- JavaScript 词法结构(构建块)
- JavaScript 变量
- JavaScript 数据类型
- JavaScript 表达式
- 原型继承
- 如何使用 JavaScript 中的 Classes(类)
- JavaScript 异常处理
- JavaScript 中的分号(;)
- JavaScript 中的引号
- JavaScript 字面量模板(Template Literals)指南
- JavaScript 中的 function(函数)
- JavaScript 箭头函数(Arrow Function)
- JavaScript 中的闭包(Closures)
- JavaScript 数组(Arrays)
- JavaScript 中的循环(Loops)
- JavaScript 中的事件(Events)
- JavaScript 中的事件循环(Event Loop)
- JavaScript 异步编程和回调
- 理解 JavaScript 中的 Promises
- 用 async 和 await 编写现代 JavaScript 异步代码
- JavaScript 中的 循环(Loops) 和 作用域(Scope)
- JavaScript 定时器 setTimeout() 和 setInterval()
- JavaScript 中的 this
- JavaScript 严格模式(Strict Mode)
- JavaScript 中的 立即执行函数表达式(IIFE)
- JavaScript 中的数学运算符
- JavaScript 中的 Math 对象
- 介绍 ES Modules(模块)
- 介绍 CommonJS
- JavaScript 术语表
JavaScript 变量
变量是分配给标识符的字面量,因此您可以稍后在程序中引用和使用它。 我们将学习如何使用 JavaScript 声明一个变量。
JavaScript 变量简介
变量是分配给标识符的字面量,因此您可以稍后在程序中引用和使用它。
JavaScript 中的变量没有附加任何类型。 将特定字面量类型分配给变量后,您可以稍后重新分配该变量,以持有任何其他类型,而不会出现类型错误或任何问题。
这就是 JavaScript 有时被称为 “无类型” 的原因。
必须先声明变量才能使用它。 有 3 种方法可以做到:使用 var
, let
或 const
。 这三种方式在以后如何与变量进行交互方面有所不同。
使用 var
在 ES2015 之前, var
是唯一可用于定义变量的构造。
var a = 0
如果您忘记添加 var
,您将为未声明的变量分配值,结果可能会有所不同。
在现代环境中,启用严格模式后,您将收到错误。 在较旧的环境中(或禁用严格模式),这将简单地初始化变量并将其分配给全局(global) 对象,在浏览器中,全局对象是 window
,在 Node.js 中,全局对象是 global
。
如果在声明变量时没有初始化变量,则在为其赋值之前,它将具有 undefined
(未定义) 的值。
var a //typeof a === 'undefined'
您可以多次重新声明变量,以覆盖它:
var a = 1 var a = 2
您还可以在同一语句中一次性声明多个变量:
var a = 1, b = 2
作用域是代码中变量的可见性。
使用任何函数外部的 var
初始化的变量将分配给全局对象,具有全局作用域并且是任何地方可见。在函数内部用 var
初始化的变量,被赋值变量的作用域是该函数,它被称为 local(本地) 作用域 或 函数作用域,只在函数内可见,就像函数参数一样。
函数中定义与全局变量名称的任何变量,可见性优先于全局变量,并将全局变量隐藏。
重要的是要理解一个 block(块)(由一对花括号标识)没有定义新的作用域。只有在创建函数时才会创建新作用域,因为 var
没有块作用域,而是函数作用域。
在函数内部,其中定义的任何变量在所有函数代码中都是可见的,即使变量是在函数末尾声明的,它仍然可以在开头引用,因为 JavaScript 在执行代码之前实际上将所有变量都移到了顶层(被称为 hoisting (提升) )。为避免混淆,请始终在函数开头声明变量。
作用域对于新手来说很容易混淆,你可以查看 深入理解 JavaScript 中的作用域和上下文 和 实例分析 JavaScript 作用域 来深入理解作用域。另外 Hoisting(提升) 这个词是用来解释 变量 和 函数声明 是如何被提升到 函数或全局 作用域顶部的。你在任何的 JavaScript 文档中找不到这个术语,我们说的 Hoisting(提升) 只是使用了其字面含义来做个比喻。如果你已经对 JavaScript 作用域工作原理有基本的了解,那么更深入的了解 JavaScript 中的 Hoisting (变量提升和函数声明提升) 有助于你建立更强大的基础知识。
使用 let
let
是 ES2015 中引入的新功能,它本质上是 var
的块作用域版本。 它的作用域仅限于定义它的 block(块)(由一对花括号标识),语句或表达式,以及所有包含的内部块。
现代 JavaScript 开发人员可能会选择仅使用 let
并完全放弃使用 var
。
let
可以在任何函数之外定义 – 与 var
相反 – let
不会创建全局变量。
使用 const
用 var
或 let
声明的变量可以稍后在程序中更改,然后重新分配。 初始化 const
后,其值永远不会再次更改,并且不能重新分配给不同的值。
const a = 'test'
我们不能为 a
常量指定不同的字面量。然而,如果 a
是一个提供方法的对象,那么我们可以更改 a
内容 。
const
不提供不可变性(immutability),只是确保不能更改引用。
const
具有块范围,与 let
相同。
现代 JavaScript 开发人员可能会选择始终将 const
用于不需要在程序中稍后重新分配的变量。
为什么? 因为我们应该始终使用最简单的结构,以避免在未来发生错误。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论