首先,一个常见的问题是,ECMAScript 和 JavaScript 到底是什么关系?
ECMAScript是一个国际通过的标准化脚本语言。JavaScript由ECMAScript和DOM、BOM三者组成。可以简单理解为:ECMAScript是JavaScript的语言规范,JavaScript是ECMAScript的实现和扩展。
这三个确实倒是有点可以说的东西,他们自身的一些特性,跟相互的区别,直接上文字吧:
var :
1、定义的变量,没有块的概念,可以跨块访问, 不能跨函数访问;
2、存在变量提升;
3、可以重复定义;
小知识点:用var定义的不能用delete删除,不用var的可以用delete删除,configurable:false(不可删除)(关于数据属性的问题:https://blog.csdn.net/weixin_42561383/article/details/90085731)
let :
1、块级作用域;
2、没有变量提升(暂时性死区);
3、不能重复定义;
const :
1、块级作用域;
2、没有变量提升(暂时性死区);
3、不能重复定义;
4、定义常量;
知识点:定义的基本类型不可不变,但是
const声明常量保存的是对象的地址,不可变的是地址,而修改对象的属性,并不会改变对象的地址,因此用const声明对象的属性是可以修改的
解释一下var的第一条
1、定义的变量,没有块的概念,可以跨块访问, 不能跨函数访问;
function doSomething () {
for (var i = 0; i < 5; i++) {
console.log(i)
}
console.log('Finally ' + i)
}
doSomething()
0 1 2 3 4 Finally 5
function doSomething () {
for (let i = 0; i < 5; i++) {
console.log(i)
}
console.log('Finally ' + i)
}
doSomething()
0 1 2 3 4
/Users/dkvirus/Documents/study/study-typescript/ex1/var.js:5
console.log('Finally ' + i)
ReferenceError: i is not defined
let 和 const 定义变量的作用域都是 离变量最近的那个块 内;
var 定义变量的作用域是 离变量最近的那个方法 内