생성자 함수를 즉시실행함수로 감싸는 이유가 궁금합니다.
예제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();
Câu trả lời 1
1
안그래도 되는게 맞습니다.
다만 생성자와 관련한 함수를 스코프로 가둠으로써 보다 명확히 구분하려는 차원에서 그렇게 작성하신게 아닐까 합니다.
나아가 당장은 스코프가 무의미하지만, 나중에 생성자함수 초기화 과정에서 한 번만 쓰일 변수가 필요해진다면 그 의의가 보다 뚜렷해질 것 같기도 하네요.
용어 발음법이 계속 바뀌는 것 같은데 이런 부분들 개선이 가능할까요...?
0
20
1
counter01.html은 어디있을까요?
1
16
1
존재하지 않는 일기 url입력 시 alert이 두 번 떠요
0
32
1
useState 직접 구현 부분에서 질문이 있습니다.
1
35
1
학습을 하고 블로그에 정리를 해도 괜찮을까요?
1
35
1
교재(3쇄)와 강의 내용 문의
0
34
2
섹션2번 부분 강의 화면이 잘 못된것 같아서 문의합니다.
0
23
1
call stack 표현이 잘못표현된것이 아닌가요?
0
75
2
React 와 Virtual DOM 의 이야기 영상 실행이 안됩니다.
0
35
1
일반 강의와 차이점?
1
54
1
!= 연산자의 역할
0
35
1
중요하진 않지만 설명하신부분에서 안된부분..
1
38
1
강의 듣는 순서가 어떻게 되나요?
0
53
1
stopPropagation()에 대해서 질문 있습니다.
0
51
2
12.13) 하단 여백 스타일링 관련 질문 드립니다.
0
67
2
27강 Context내 RSC 사용 관련 문의
0
86
3
혹시 다음 강의 제작 예정된 것들이 있을까요?
0
89
1
Enable Linting 항목을 찾을수가 없습니다.
0
46
2
브라우저의 ES6 모듈(ESM)을 사용하도록 Babel을 설정
0
282
2
할당문
0
337
1
함수 부분 질문입니다.
0
502
1
실행컨텍스트에서 BindingObject를 통한 객체의 프로퍼티와 메서드 질문
0
584
1
코어 자바스크립트 예제 5-14 질문
0
551
3
안녕하세요.
0
462
1

