(JavaScript) 스코프(Scope)란?. 자바스크립트를 공부할 때 스코프(Scope)란 단어를 많이 접할 수… | by Su Bak | Medium

notion imagenotion image
자바스크립트를 공부할 때 스코프(Scope)란 단어를 많이 접할 수 있는데요. 이 스코프란 무엇인지에 대해 알아보겠습니다.
Scope를 우리말로 번역하면 ‘범위’라는 뜻을 가지고 있습니다. 즉, 스코프(Scope)란 ‘변수에 접근할 수 있는 범위’라고 할 수 있는데요.
자바스크립트에선 스코프는 2가지 타입이 있습니다. 바로 global(전역)과 local(지역) 인데요.
전역 스코프(Global Scope)는 말 그대로 전역에 선언되어있어 어느 곳에서든지 해당 변수에 접근할 수 있다는 의미이고 지역 스코프(Local Scope)는 해당 지역에서만 접근할 수 있어 지역을 벗어난 곳에선 접근할 수 없다는 의미입니다.
자바스크립트에서 함수를 선언하면 함수를 선언할 때마다 새로운 스코프를 생성하게 됩니다. 그러므로 함수 몸체에 선언한 변수는 해당 함수 몸체 안에서만 접근할 수 있는데요. 이걸 함수 스코프(function-scoped)라고 합니다. 함수 스코프가 바로 지역 스코프의 예라고 할 수 있습니다.
아래의 예제 코드를 통해 전역 스코프, 지역(함수) 스코프를 더 자세히 알아보겠습니다.
function print() { // 지역(함수) 스코프 var a = 111; console.log(a); }
위의 예제에서 print함수를 호출하면 console엔 1이 출력될까요? 아니면 111이 출력될까요?
print 함수를 호출하면 111이 출력되는 것을 볼 수 있습니다.
function print() { // 지역(함수) 스코프 var a = 111; console.log(a); }console.log(a); // 1
print 함수에서 console.log(a);는 a를 출력하기 위해 자신의 함수 스코프 안에 변수 a가 있는지 찾아볼 것입니다. 그러면 var a = 111; 을 찾아내면 111을 console에 출력하고 함수는 자신의 사명을 다하게 됩니다.
만약 print 함수 안에 변수 a의 선언을 지운다면 console엔 어떤 값이 출력될까요? 함수 스코프 안에 a가 존재하지 않으니까 a가 선언되어있지 않다는 에러를 출력할까요? 한 번 print 함수를 다시 선언하고 실행해보겠습니다.
function print() { // 함수 스코프 console.log(a); }
결과는 예상과는 다르게 전역 스코프에 선언되어있는 a의 값인 1이 출력되는 것을 확인할 수 있습니다. 이는 Scope Chain에 의해 일어나는 현상인데요. 현재 자신의 scope에서 사용하고자 하는 변수가 없다면 Scope Chain을 통해 해당 변수를 찾게됩니다. Scope Chain에 대한 이야기는 후에 다른 글에서 한번 더 정리를 해보도록 하겠습니다.
함수 스코프외에 블록 스코프란 것도 있는데요. 블록(block)이란 중괄호로 둘러싸인 부분을 블록이라고 합니다. 함수를 선언할 때 중괄호로 함수 본문을 둘러싸게 되는데 이부분을 블록이라고 할 수 있습니다.
function print() { // 함수 블록 console.log(a); }{ // 블록 const a = '1'; }
기존 var의 경우 함수 스코프를 가졌기 때문에 함수 내에서만 지역변수가 유지되는 문제가 있었는데요. ES2015(ES6)에서 let / const 키워드가 추가되면서 함수가 아닌 일반 블록에서도 지역변수를 선언할 수 있게 되었습니다.
var, let, const에 대해선 다른 글에서 더 자세히 다뤄보도록 하겠습니다.
이번 글에선 자바스크립트의 스코프(Scope)에 대해 알아보았습니다.
부족한 글을 읽어주셔서 감사합니다.