js声明变量三种方式

变量声明的三种方式:

  1. let
  2. const
  3. var

var 声明与 let 相似。大部分情况下,我们可以用 let 代替 var 或者 var 代替 let,都能达到预期的效果。

let和var的区别:

1、“var” 没有块级作用域

用 var 声明的变量,不是函数作用域就是全局作用域。它们在代码块外也是可见的(译注:也就是说,var 声明的变量只有函数作用域和全局作用域,没有块级作用域)。

if (true) {
  var test = true; // 使用 "var" 而不是 "let"
}

alert(test); // true,变量在 if 结束后仍存在

 由于 var 会忽略代码块,因此我们有了一个全局变量 test

如果我们在第二行使用 let test 而不是 var test,那么该变量将仅在 if 内部可见:

if (true) {
  let test = true; // 使用 "let"
}

alert(test); // Error: test is not defined

对于循环也是这样的,var 声明的变量没有块级作用域也没有循环局部作用域:

for (var i = 0; i < 10; i++) {
  var one = 1;
  // ...
}

alert(i);   // 10,"i" 在循环结束后仍可见,它是一个全局变量
alert(one); // 1,"one" 在循环结束后仍可见,它是一个全局变量

如果一个代码块位于函数内部,那么 var 声明的变量的作用域将为函数作用域:

function sayHi() {
  if (true) {
    var phrase = "Hello";
  }

  alert(phrase); // 能正常工作
}

sayHi();
alert(phrase); // Error: phrase is not defined

可以看到,var 穿透了 iffor 和其它代码块。这是因为在早期的 JavaScript 中,块没有词法环境,而 var 就是这个时期的代表之一。

“var” 允许重新声明

如果我们用 let 在同一作用域下将同一个变量声明两次,则会出现错误:

let user;
let user; // SyntaxError: 'user' has already been declared

 使用 var,我们可以重复声明一个变量,不管多少次都行。如果我们对一个已经声明的变量使用 var,这条新的声明语句会被忽略。

总结:

以前使用的var和val一个是可变和不可变的变量;现在都是用let和const声明变量,现在的标准基本都是let和const了。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值