생성자 함수를 즉시실행함수로 감싸는 이유가 궁금합니다.
예제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();
回答 1
1
안그래도 되는게 맞습니다.
다만 생성자와 관련한 함수를 스코프로 가둠으로써 보다 명확히 구분하려는 차원에서 그렇게 작성하신게 아닐까 합니다.
나아가 당장은 스코프가 무의미하지만, 나중에 생성자함수 초기화 과정에서 한 번만 쓰일 변수가 필요해진다면 그 의의가 보다 뚜렷해질 것 같기도 하네요.
React 와 Virtual DOM 의 이야기 영상 실행이 안됩니다.
0
24
1
일반 강의와 차이점?
1
33
1
!= 연산자의 역할
0
32
1
중요하진 않지만 설명하신부분에서 안된부분..
0
28
0
강의 듣는 순서가 어떻게 되나요?
0
42
1
stopPropagation()에 대해서 질문 있습니다.
0
42
2
12.13) 하단 여백 스타일링 관련 질문 드립니다.
0
57
2
27강 Context내 RSC 사용 관련 문의
0
69
3
혹시 다음 강의 제작 예정된 것들이 있을까요?
0
64
1
Enable Linting 항목을 찾을수가 없습니다.
0
42
2
에러 질문드립니다
0
58
2
1강 질문
0
59
2
윈도우에서는동작줄이기가어디에있을까요??
0
31
1
백오피스를 개발할 때 아키텍처 구성에 대한 질문
0
46
3
ai가 만든 강의인가요?
0
109
1
VSCode 설정 문의
0
63
2
PPT 코드 관련 질문
0
46
2
state 객체로 묶기
0
45
1
브라우저의 ES6 모듈(ESM)을 사용하도록 Babel을 설정
0
281
2
할당문
0
337
1
함수 부분 질문입니다.
0
500
1
실행컨텍스트에서 BindingObject를 통한 객체의 프로퍼티와 메서드 질문
0
583
1
코어 자바스크립트 예제 5-14 질문
0
545
3
안녕하세요.
0
462
1

