JavaScript
[JavaScript] 변수란? var, let, const의 차이점
CooNiHong
2021. 10. 17. 20:35
변수(variable)란?
변수는 간단하게 데이터를 저장하는 곳입니다. 변수는 하나의 값을 저장하기 위해 확보한 메모리 공간 자체 또는 그 메모리 공간을 식별하기 위해 붙인 이름을 말합니다.
사용하는 이유
흔히 이름, 나이와 같은 데이터를 저장할 수도 있고 DOM의 셀렉터로 찾은 HTML 요소도 저장할 수 있습니다. document.querySelector와 같은 셀렉터를 탐색하는 명령어를 매번 사용하면 사용할 때마다 DOM을 탐색해야 하지만 여러 번 사용하게 될 때 변수에 저장해두면 한 번만 탐색하고 저장한 데이터를 바로바로 사용하니 JavaScript의 동작속도를 조금 더 빠르게 할 수 있습니다.
var
- 함수(function) 레벨 스코프입니다.
function test() {
var age = 22;
}
console.log(age); // age is not defined
함수 안에서 선언한 var 변수는 밖에서 사용할 수 없습니다.(지역 변수)
함수 밖에서 선언한 var 변수는 함수 안에서 사용할 수 있습니다.(전역 변수)
- 중복 선언이 가능합니다.
var age = 22;
var age = 23;
console.log(age); // 23
- 재할당이 가능합니다.
var age = 22;
age = 23;
console.log(age); // 23
- 호이스팅 현상이 일어납니다.
console.log(name); // undefined
var name = 'john';
Error가 발생하진 않지만 undefined로 출력하며 실행은 가능합니다.
let
- 블록(block) 레벨 스코프입니다.
if문과 같은 {} 안에서 생성한 변수들은 밖에서 사용할 수 없습니다.
- 중복 선언이 불가능합니다.
let age = 22;
let age = 22; // Identifier 'age' has already been declared
- 재할당이 가능합니다.
let age = 22;
age = 23;
console.log(age); // 23
const
- 블록(block) 레벨 스코프입니다.
- 중복 선언이 불가능합니다.
- 재할당이 불가능합니다.
const name = 'john';
name = 'jon'; // Assignment to constant variable.
스코프 | 재선언 | 재할당 | |
var | function () {} | O | O |
let | { block level } | X | O |
const | { block level } | X | X |
식별자 네이밍 규칙
- 변수의 이름(식별자)에 특수문자를 제외한 문자, 숫자, 언더바(_), $기호를 포함할 수 있다.
- 식별자는 숫자로 시작할 수 없다.
- 예악어는 식별자로 사용할 수 없다.
- if, for, case, let, var, const, this 등등
- 한글도 가능하지만 영어로 작성하는것을 권장한다.
- 변수명을 봤을때 존재 목적을 명확히 알 수 있는 이름으로 지어야한다.
네이밍 컨벤션
식별자를 명명하는데 여러가지 유형이 존재합니다.
- 카멜 케이스(camelCase)
- 스네이크 케이스(snake_case)
- 파스칼 케이스(PascalCase)
- 헝가리언 케이스(typeHungarianCase) - type과 변수명을 같이 작성하는 케이스
728x90