자바스크립트에서 변수에 대한 호이스팅이라는 개념이 있습니다. 함수 안에 정의된 모든 변수는 선언된 그 위치에 상관없이 함수의 윗부분으로 끌어올려(hoist)된다라는 개념입니다. 여기서 주의할 점은 자바스크립트에서 함수도 객체 변수이며 이 함수가 호이스팅될때입니다.. 함수를 정의하고 선언하는 방법을 크게 2가지로 구분할 수 있습니다.
- 표현식에 의한 정의
- 선언문에 의한 정의
먼저 표현식에 의한 정의의 예는 다음과 같습니다.
var bar = function() { // 표현식에 의한 함수 정의 };
다음은 선언문에 의한 정의의 예입니다.
function foo() { // 선언문에 의한 함수 정의 }
이러한 함수 정의가 함수 안에서 이루어질때 호이스팅에 차이가 발생하게 됩니다.
function test() { alert(typeof foo); alert(typeof bar); function foo() { // 선언문에 의한 함수 정의 } var bar = function() { // 표현식에 의한 함수 정의 }; } test();
위의 코드를 실행해 보면 처음에는 “function”이라는 메세지가 표시되고 다음에는 “undefined”라는 메세지가 표시됩니다. 이는 표현식에 대한 함수 정의시에 함수 객체가 호이스팅될때 함수의 코드부분은 호이스팅되지 않지만 선언문으로 함수가 정의될 경우에는 함수의 코드부분까지도 호이스팅된다는 것을 알 수 있습니다.