자바스크립트의 끌어올림(호이스팅) 이해하기

  • 2 minutes to read

1. 호이스팅(끌어올림)이란?

자바스크립트에서 변수나 함수의 선언을 코드 상에서의 위치와 상관없이 스코프의 최상단으로 끌어올리는 현상을 호이스팅이라고 합니다. 이 현상은 자바스크립트의 실행 컨텍스트의 특징 때문에 발생합니다.

2. 변수의 호이스팅

자바스크립트에서는 var로 변수를 선언할 때, 해당 변수의 선언 부분만 스코프의 최상단으로 끌어올려집니다. 할당은 원래 코드의 위치에서 이루어집니다.

console.log(name); // undefined
var name = 'John';
console.log(name); // John

이 코드는 내부적으로 아래와 같이 동작합니다:

var name; // 선언이 끌어올려짐
console.log(name); // undefined
name = 'John'; // 할당은 원래 위치에서
console.log(name); // John

3. 함수의 호이스팅

함수 선언식은 선언과 함께 정의도 같이 끌어올려집니다. 하지만 함수 표현식은 변수 호이스팅과 같은 방식으로 처리됩니다.

console.log(greet()); // Hello
function greet() {
  return 'Hello';
}

console.log(sayHello); // undefined
var sayHello = function() {
  return 'Hi!';
};
console.log(sayHello()); // Hi!

4. 주의사항

  • ES6의 letconstvar와 다르게 호이스팅은 되지만, 초기화 되지 않은 상태에서 참조하면 ReferenceError를 발생시킵니다.
  • 함수 호이스팅은 함수 선언식에만 적용되며, 함수 표현식에는 적용되지 않습니다.

5. 결론

호이스팅은 자바스크립트의 독특한 특징 중 하나입니다. 이를 이해하고 올바르게 코드를 작성하는 것은 중요하며, 특히 변수나 함수를 사용하기 전에 선언하는 습관을 기르는 것이 좋습니다.

더 깊이 공부하고 싶다면
DevLec에서는 실무 중심의 C#, .NET, ASP.NET Core, Blazor, 데이터 액세스 강좌를 단계별로 제공합니다. 현재 수강 가능한 강좌 외에도 더 많은 과정이 준비되어 있습니다.
DevLec.com에서 자세한 커리큘럼을 확인해 보세요.
DevLec 공식 강의
C# Programming
C# 프로그래밍 입문
프로그래밍을 처음 시작하는 입문자를 위한 C# 기본기 완성 과정입니다.
ASP.NET Core 10.0
ASP.NET Core 10.0 시작하기 MVC Fundamentals Part 1 MVC Fundamentals Part 2
웹 애플리케이션의 구조와 MVC 패턴을 ASP.NET Core로 실습하며 익힐 수 있습니다.
Blazor Server
풀스택 웹개발자 과정 Part 1 풀스택 웹개발자 과정 Part 2 풀스택 웹개발자 과정 Part 3
실무에서 바로 활용 가능한 Blazor Server 기반 관리자·포털 프로젝트를 만들어 봅니다.
Data & APIs
Entity Framework Core 시작하기 ADO.NET Fundamentals Blazor Server Fundamentals Minimal APIs
데이터 액세스와 Web API를 함께 이해하면 실무 .NET 백엔드 개발에 큰 도움이 됩니다.
VisualAcademy Docs의 모든 콘텐츠, 이미지, 동영상의 저작권은 박용준에게 있습니다. 저작권법에 의해 보호를 받는 저작물이므로 무단 전재와 복제를 금합니다. 사이트의 콘텐츠를 복제하여 블로그, 웹사이트 등에 게시할 수 없습니다. 단, 링크와 SNS 공유, Youtube 동영상 공유는 허용합니다. www.VisualAcademy.com
박용준 강사의 모든 동영상 강의는 데브렉에서 독점으로 제공됩니다. www.devlec.com