CLASS web

JavaScript

hoisting(호이스팅)

hoisting(호이스팅)

건축분야에서 호이스팅이라는 단어를 자주사용합니다. hoisting는 들어올리기 라는 뜻이지요.

자바스크립트에서도 이 단어가 사용됩니다.

우리는 이미 호이스팅에 대해서 학습을 했습니다.

함수표현식

위의 강좌에서 마지막 부분에 설명한 내용이 호이스팅입니다.

함수선언식으로 선언한 함수나 변수 선언은 최상단으로 끌어올립니다.

그래서 코드상에서 함수를 호출후에 함수 선언식으로 선언한 함수를 호출해도 작동을합니다.

단, 함수표현식은 그렇지가 않습니다.

그럼 여기에서 다시한번 해봅시다.

함수선언식, 함수표현식, 화살표표기법이 어떻게 나오는지 봅시다.

함수선언식 호이스팅

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>pinkcoding - JavaScript</title>
<script>
    hoisting();

    function hoisting(){
        document.write('I am here');
    }
</script>
</head>
<body>
</body>
</html>

결과는 바로 아래에서 확인할 수 있습니다.







JavaScript hoisting

위와 같이 함수 선언전에 함수를 호출해도 결과가 잘 나타납니다.

함수표현식 호이스팅

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>pinkcoding - JavaScript</title>
<script>
    hoisting();

    const hoisting = function(){
        document.write('I am here');
    }
</script>
</head>
<body>
</body>
</html>

결과는 바로 아래에서 확인할 수 있습니다.







JavaScript hoisting

앞에서 했던것과 같이 함수는 작동하지 않습니다.

화살표표기법 호이스팅

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>pinkcoding - JavaScript</title>
<script>
    document.write(hoisting());

    const hoisting = () => 'I am here';
</script>
</head>
<body>
</body>
</html>

결과는 바로 아래에서 확인할 수 있습니다.







JavaScript hoisting

화살표표기법도 먼저 함수를 선언하고 호출되어야하네요.

호이스팅은 이외에도 스코프에 대한 개념도 알면 좋습니다.

스코프(scope)는 범위를 뜻하지요.

그럼 다음시간에 스코프에 대해서 알아봅시다.





댓글 0개

정렬기준

PinkCoding

PinkCoding

X

PinkCoding

Web Scratch Pad

X

loading

            
            
        

컨텐츠로 돌아가기