欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

ES6的let、const

程序员文章站 2024-01-01 22:55:40
...

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>

ES6的let、const

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>

ES6的let、const

ES6的let、const

ES6的let、const

相关标签: js

上一篇:

下一篇: