>웹 프론트엔드 >프런트엔드 Q&A >es6에서 let과 var의 차이점은 무엇입니까?

es6에서 let과 var의 차이점은 무엇입니까?

WBOY
WBOY원래의
2022-03-31 15:08:422453검색

차이점: 1. let 변수의 범위는 정의된 블록 수준 코드에 있는 반면, var 변수의 범위는 이를 포함하는 함수 범위에 있습니다. 2. Let 변수는 반복적으로 선언할 수 없지만 var 변수입니다. 반복 가능 명령문; 3. 코드 실행 전에 스캔하면 var 변수가 정의되지 않은 상태로 초기화되지만 let 변수는 초기화되지 않습니다.

es6에서 let과 var의 차이점은 무엇입니까?

이 튜토리얼의 운영 환경: Windows 10 시스템, ECMAScript 버전 6.0, Dell G3 컴퓨터.

es6에서 let과 var의 차이점은 무엇인가요?

let은 var로 인해 발생하는 다양한 문제를 개선하기 위해 ES6에서 새로 도입된 키워드입니다.

var와 비교하면 let과 var의 차이점은 대략 다음과 같습니다.

1. 범위

  • let으로 정의된 변수의 경우 범위는 해당 변수가 정의된 블록 수준 코드와 하위 항목입니다. 블록에 포함되며 전역 범위에는 변수를 추가할 수 없습니다.

  • var를 통해 정의된 변수의 범위는 이를 포함한 함수 범위 또는 전역 범위입니다.

2. 반복 선언

  • let을 통해 정의된 변수는 동일한 범위에서 반복적으로 선언될 수 없습니다.

  • var를 통해 정의된 변수는 동일한 범위에서 반복적으로 선언됩니다. 실행 컨텍스트 생성 시 이후 선언은 무시됩니다.

3. 임시 데드존으로 인한 승격 등의 문제

우리는 코드가 실행되기 전에 모든 필드에서 var로 선언된 변수를 먼저 스캔하고 정의되지 않은 상태로 초기화한 다음 코드가 실행된다는 것을 알고 있습니다. 이른바 '승천' 현상이다.

그러나 let으로 선언된 변수의 경우에는 다릅니다. 코드가 실행되기 전의 스캔도 let 변수를 "발생"시키지만 정의되지 않음으로 설정하지는 않습니다. let으로 정의된 변수는 승격되었으나 변수를 초기화하는 코드가 실행되기 전에는 초기화되지 않았습니다. 이때 액세스하면 ReferenceError가 설정됩니다. 코드 블록 시작부터 실행, let 변수 초기화 완료까지 let 변수가 선언되었으나 접근이 불가능합니다. 이 기간을 임시 데드존이라고 합니다.

【관련 추천: javascript 비디오 튜토리얼, web front-end

위 내용은 es6에서 let과 var의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.