호이스팅: 스코프를 단위로 동작, 변수 선언이 스코프의 선두로 끌어 올려진 것처럼 동작하는 자바스크립트 고유의 특징
전역 객체: 코드가 실행 되기 이전 단계에 자바스크립트 엔진에 의해 어떤 객체보다도 먼저 생성 되는 특수한 객체
=> 표준 빌트인 객체(Object, String. Number, Function, Array), 환경에 따른 호스트 객체(클라이언트 Web
API 또는 Nodejs의 호스트 API), var 키워드로 선언한 전역 변수와 전역 함수를 프로퍼티를 가짐
암묵적 결합
: 모든 코드가 전역 변수를 참조하고 변경할 수 있는 것
-> 변수의 유효 범위가 크기 때문에 가독성은 나빠짐, 의도치 않게 상태가 변경될 수 있는 위험성은 높아짐
긴 생명 주기
메모리 리소스 오랜 기간 소비, 상태를 변경할 가능성 높음, var 키워드는 변수의 중복 선언을 허용해서 의도치 않은 재할당 가능
스코프 체인 상에서 종점에 존재
-> 변수 검색 시 가장 마지막에 검색 => 전역 변수의 검색 속도가 가장 느림
네임스페이스 오염
js는 파일이 분리되어 있어도 하나의 전역 스코프를 공유함
-> 다른 파일 내에서 동일한 이름으로 명명된 전역 변수나 함수가 같은 스코프 내에 존재할 경우 예상치 못한 결과 발생 가능
전역 변수를 반드시 사용해야 할 이유를 찾지 못한다면 지역 변수를 사용해야함 -> 변수의 스코프는 좁을수록 좋기 때문
=> 아래 전역 변수의 사용을 억제할 수 있는 방법들 소개
함수 정의와 동시에 호출되는 즉시 실행함수는 한 번만 호출됨
-> 모든 코드를 즉시 실행함수로 감싸면 모든 변수는 즉시 실행 함수의 지역 변수가 됨 (라이브러리 등에 자주 사용)
=> 함수를 ()로 감싸기
네임스페이스 역할을 담당할 객체를 생성하고 전역 변수처럼 사용하고 싶은 변수를 프로퍼티로 추가하는 것
-> 네임스페이스를 분리해서 식별자 충돌을 방지하는 효과는 있음
-> 객체 자체가 전역 변수에 할당되므로 그다지 유용해 보이지 않음
클래스를 모방해서 관련이 있는 변수와 함수를 모아 즉시 실행 함수로 감싸 하나의 모듈을 만드는 것 -> 클로저를 기반으로 동작
=> 전역 변수의 억제 & 캡슐화까지 구현 가능
캡슐화: 객체의 상태를 나타내는 프로퍼티와 프로퍼티를 참조하고 조작할 수 있는 동작인 매서드를 하나로 묶는 것
-> 정보 은닉(객체의 특정 프로퍼티나 메서드를 감출 목적)을 위해 사용
var Counter = (function() {
// private 변수
var num = 0;
// 외부로 공개할 데이터나 메서드를 프로퍼티로 추가한 객체를 반환
return {
increase() {
return ++num;
},
decrease() {
return --num
}
}
})();
// private 변수는 외부로 노출되지 않음
console.log(Counter.num); // undefined
console.log(Counter.increase()); // 1
console.log(Counter.decrease()); // 0
=> 즉시 실행 함수는 객쳬를 반환
-> 퍼블릭 멤버
: 외부에 노출하고 싶은 변수나 함수를 담아 반환
-> 프라이빗 멤버
: 외부로 노출하고 싶지 않은 변수나 함수는 반환하는 객쳬에 추가하지 않으면 외부에서 접근 불가