let 및 const로 선언된 변수는 코드 블록 내에서만 유효합니다
{ let a = 10; var b = 1; } a // ReferenceError: a is not defined. b // 1
변수 승격이 없습니다
변수 선언 후에는 Use에 있어야 합니다. 그렇지 않으면 오류가 보고됩니다.
var tmp = 123; if (true) { tmp = 'abc'; // ReferenceError let tmp; }
// 报错 function () { let a = 10; var a = 1; }
function f() { console.log('I am outside!'); } (function () { if(false) { // 重复声明一次函数f function f() { console.log('I am inside!'); } } f(); }()); //I am inside! ES5 函数提升 //I am outside! ES6 块级作用域
한번 선언된 변수는 즉시 초기화되어야 하며 나중에 할당할 수 없습니다
전역 변수 선언 let 명령에 의해 const 명령과 class 명령은 전역 객체 속성에 속하지 않습니다
var a = 1; // 如果在Node的REPL环境,可以写成global.a // 或者采用通用方法,写成this.a window.a // 1 let b = 1; window.b // undefined
const foo='foo'; foo='bar';//TypeError: Assignment to constant variable.
const foo=[]; foo=[1];//Assignment to constant variable.
왜 오류가 보고되지 않나요? 그리고 수정이 성공할 수 있을까요? 이 두 예제의 차이점은 전자는 포인터를 수정하고(js 참조 유형에 익숙해야 함) 해당 내용이 변경된 반면, 후자는 동일한 것을 가리키지 않지만 객체의 내용이 변경되었다는 것입니다. foo의 경우 포인터는 해당 개체를 가리키는 역할만 합니다. 개체의 내용은 중요하지 않으므로 내용이 변경되는 것을 원하지 않으면 수정할 수 있습니다. 다른 방법을 사용할 수 있습니다.
const foo=[1,2,3]; foo[1]=4; console.log(foo)//[1, 4, 3]
const foo=Object.freeze([1,2,3]); foo[1]=4; console.log(foo)//[1, 2, 3]