es6,js系列教程之变量(一)

1、变量

变量 是数据的“命名存储”。我们可以使用变量来保存商品、访客和其他信息。

var

全局变量 如:

var a = 2  
window.a=2

let

局部变量声明, 只在区块内起作用,外部是不可以调用的。有三个特点:

  • 不存在变量提升

var命令会发生“变量提升”现象,即变量可以在声明之前使用,值为undefined。这种现象多多少少是有些奇怪的,按照一般的逻辑,变量应该在声明语句之后才可以使用。为了纠正这种现象,let命令改变了语法行为,它所声明的变量一定要在声明后使用,否则报错。

  • 暂时性死区

只要块级作用域内存在let命令,它所声明的变量就“绑定”(binding)这个区域,不再受外部的影响。

  • 不允许重复声明

let不允许在相同作用域内,重复声明同一个变量。

const

声明一个只读的常量。一旦声明,常量的值就不能改变。(只在声明所在的块级作用域内有效。)

不存在常量提升, 同样存在暂时性死区, 只能在声明的位置后面使用。
 

本质:const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址所保存的数据不得改动。

const foo = {};
// 为 foo 添加一个属性,可以成功
foo.prop = 123;
foo.prop // 123
// 将 foo 指向另一个对象,就会报错
foo = {}; // TypeError: "foo" is read-only

变量总结:

var

  • 支持全局、函数作用域
  • 接受重复声明
  • 变量预解析

let

  • 不接受重复声明
  • 不存在变量提升
  • 支持块作用域

const

  • 特性同let
  • 一旦声明,常量的值就不可以改变

测试题:

1、最终a输出的值是多少

var a = 1;
{
 let a = 10;
}
console.log(a)
   

2、fn()最终n输出的值是多少

function fn() {
  let n = 5;
  if (true) {
    let n = 10;
  }
  console.log(n); 
}
fn()

3、最终f()输出是多少

var tmp = new Date();
function f() {
  console.log(tmp);
  if (false) {
    var tmp = 'hello world';
  }
}

f();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

科技百宝箱

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值