java const let_5分钟掌握var,let和const异同

转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。

原文出处:https://dzone.com/articles/javascript-difference-between-var-let-and-const-ke

这个话题对于一些老鸟来说可能根本算不上疑问,但对于新手来说也许除了最常见的var之外,let和const较少使用的机会。

所以在本文中,我将会通过一些例子来为大家介绍如何在Javascript中灵活使用var、let和const这些关键字来定义变量,以及这些关键字它们之间有什么异同。

如果你懒得看下面的代码,那我可以先把概念结论说出:

var定义的变量可被更改,如果不初始化而直接使用也不会报错

let定义的变量和var类似,但作用域在当前声明的范围内

const定义的变量只可初始化一次且作用域内不可被更改,使用前必须初始化

下面我将通过示例的形式来详细为大家介绍它们三者之间的异同:

Var

var用以声明一个变量,并且同时我们可以在声明语句中初始化所声明的变量。

例如:

var a = 10;

变量的声明,会在代码被执行之前被处理。

用var声明的JavaScript变量,其可用范围在当前执行上下文。

在函数外声明的JavaScript变量,其作用范围是全局。

考虑以下代码片段:

48304ba5e6f9fe08f3fa1abda7d326ab.png

function nodeSimplified() {

var a =10;

console.log(a); // 输出 10

if(true) {

var a=20;

console.log(a); // 输出 20

}

console.log(a); // 输出 20

}

48304ba5e6f9fe08f3fa1abda7d326ab.png

在上面的代码中,你可以发现,当变量a在if代码段里被更新时,它的值被全局更新了,因此在经过了if代码后,被更新的值仍然被保留着。这与其他语言中的全局变量有点类似。但是,在使用这个功能时要非常小心,因为它有可能会覆盖一个已有的值。

let

let语句在一个块级范围里声明一个局部变量。和var类似,我们可以在声明时初始化它的值。

例如:

let a = 10;

这个语句允许你创建一个变量,使它的作用范围被限制在它所在的代码块。

它和Java、C#等其他语言的变量类似。

考虑下面的代码片段:

48304ba5e6f9fe08f3fa1abda7d326ab.png

function nodeSimplified() {

let a =10;

console.log(a); // output 10

if(true) {

let a=20;

console.log(a); // output 20

}

console.log(a); // output 10

}

48304ba5e6f9fe08f3fa1abda7d326ab.png

它和大多数语言中我们所见的表现行为是一致的。

function nodeSimplified() {

let a =10;

let a =20; // 抛出语法错误

console.log(a);

}

错误信息:"未捕获的异常:标识符'a'已经被声明过。" 但如果使用var就没事:

function nodeSimplified() {

var a =10;

var a =20;

console.log(a); // 输出 20

}

使用let语句,可以很好的维护变量的作用范围。当使用内部函数时,let语句让你的代码更整洁。

我希望上面的例子能帮你更好地理解var和 let。如果有任何疑问,请在评论区留言。

const

const语言中的变量只能被赋值一次,然后就不能在被赋值。const语句的作用范围和let语句一样。

例如:

const a = 10;

function nodeSimplified() {

const MY_VARIABLE =10;

console.log(MY_VARIABLE); // 输出 10

}

照例,命名规范指出我们应该用大写字母声明常量。当然,const a = 10 在上面的代码中会的起到相同的作用。为了让代码长期可维护,命名规范还是值得遵守的。

问题:如果给一个const变量重新赋值会发生什么? 考虑下面的代码:

48304ba5e6f9fe08f3fa1abda7d326ab.png

function nodeSimplified() {

const MY_VARIABLE =10;

console.log(MY_VARIABLE); // 输出 10

MY_VARIABLE =20; // 抛出类型错误

console.log(MY_VARIABLE);

}

48304ba5e6f9fe08f3fa1abda7d326ab.png

错误信息:"未捕获的类型错误:给const变量赋值"。

当我们尝试给已有的const变量赋值时,这段代码会抛出一个错误。

介绍就到此结束,希望这篇短小精悍的文章能够帮助到各位更好的理解在Javascript中声明变量时使用不同关键字上到底有何异同。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值