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>
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>