ES6的let、const

ES6的let、const

块级作用域:

作用域:其实就是有某个范围内可用也就是在某个{}内可用。

1.let和var的区别

1.1 let的由来

事实上var可以看成是JS语言在设计上的缺陷,但是这种错误多半不能修复和移除,以为需要向后兼容。
于是作者添加了一个新的关键字: let
可以将let看成完美的var。

1.2 区别

let有块级作用域
var没有块级作用域,也就是说它是全局的。

ES5之前因为if 和 for 都没有块级作用域的概念,所以在很多时候,我们都必须借助于function的作用域解决应用外面得变量的问题。
ES6中,加入了let 他是有if和for的块级作用域

//1.变量的块级作用域:变量在什么范围内是可用的。
<script>
  //1.变量的块级作用域:变量在什么范围内是可用的。
    {
        var action = 'var出来了';
        console.log(action);
    }
  console.log(action);

    //没有块级作用域回引起的问题
    if (false){
        var age = 10;
    }
    age = 100;
  console.log(age);

  console.log("--------------------------")
  var high = 1;
  console.log('var:' + high);
  // 有块及作用域
  if (true){
      let high;
      high = 100;
      console.log('let:' + high);
  }
  console.log('var:' + high);
</script>

在这里插入图片描述

2.let 和 const

let 和 const 都是有块级用域的。
let:
用来定义变量的

const:
用来定义常量,就是定义之后就不能再修改了。
开发时优先使用const, 当需要改变标志的变量的时候,才用let
注意:
1.当你想修改你用const 修饰的常量之后,再修改时会报错的。
2.当你定义变量的时候必须赋值。
3.常量的含义是指你不可以改变对象的指向(也就是地址),可以改变对象内部的属性。

<script>
  let age = 0;
  const name = '张三';
  age = 10;
  // 可以修改对象里面的属性
  const student = {name: '张三', age: age};
  console.log(student.name = '111');

  // 不能修改
  name = '李四';

  // 必须初始化
  const person;

</script>

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值