inflearn logo
강의

Course

Instructor

Modern JavaScript Deep Dive Study

생성자 함수를 즉시실행함수로 감싸는 이유가 궁금합니다.

Resolved

820

jane

6 asked

1

예제25-01을 보면

생성자를 즉시실행함수로 감싸는 패턴이 있던데요.

var Person = (function(){ 
    function Person(name) { 
        this.name = name;
    }
    Person.prototype.sayHi = function(){ 
        console.log('Hi! My name is ' + this.name);
    };
    return Person; 
})(); 
var me = new Person('Lee');
me.sayHi();

굳이 이렇게 하는 이유는 무엇인가요?

아래와 같이 그냥 일반 함수 선언문으로 해도 될것 같은데요.

function Person(name) { 
    this.name = name;
}

Person.prototype.sayHi = function(){ 
        console.log('Hi! My name is ' + this.name);
}
var me = new Person('Lee');
me.sayHi();

혹시 함수 호이스팅? 때문에 그런거면 변수에 생성자를 할당해면 될것 같은데요...

즉시실행함수를 쓰는 이유를 도무지 모르겠네요;

var Person = function Person(name) { 
    this.name = name;
}

Person.prototype.sayHi = function(){ 
        console.log('Hi! My name is ' + this.name);
}

var me = new Person('Lee');
me.sayHi();

즉시실행함수 javascript

Answer 1

1

jaenam

안그래도 되는게 맞습니다.
다만 생성자와 관련한 함수를 스코프로 가둠으로써 보다 명확히 구분하려는 차원에서 그렇게 작성하신게 아닐까 합니다.
나아가 당장은 스코프가 무의미하지만, 나중에 생성자함수 초기화 과정에서 한 번만 쓰일 변수가 필요해진다면 그 의의가 보다 뚜렷해질 것 같기도 하네요.

중요하진 않지만 설명하신부분에서 안된부분..

0

5

0

강의 듣는 순서가 어떻게 되나요?

0

19

1

stopPropagation()에 대해서 질문 있습니다.

0

28

2

12.13) 하단 여백 스타일링 관련 질문 드립니다.

0

39

2

27강 Context내 RSC 사용 관련 문의

0

42

3

혹시 다음 강의 제작 예정된 것들이 있을까요?

0

41

1

Enable Linting 항목을 찾을수가 없습니다.

0

32

2

에러 질문드립니다

0

40

2

1강 질문

0

41

2

윈도우에서는동작줄이기가어디에있을까요??

0

23

1

백오피스를 개발할 때 아키텍처 구성에 대한 질문

0

32

2

ai가 만든 강의인가요?

0

82

1

VSCode 설정 문의

0

48

2

PPT 코드 관련 질문

0

39

2

state 객체로 묶기

0

37

1

몽고 db 접속 오류

0

22

1

3강 질문

0

65

2

74. 데이터 캐시 - 1 (이론) 강의 영상 누락

0

44

1

브라우저의 ES6 모듈(ESM)을 사용하도록 Babel을 설정

0

280

2

할당문

0

334

1

함수 부분 질문입니다.

0

498

1

실행컨텍스트에서 BindingObject를 통한 객체의 프로퍼티와 메서드 질문

0

582

1

코어 자바스크립트 예제 5-14 질문

0

543

3

안녕하세요.

0

462

1