Prototype [펌] prototype (2)

황제낙엽 2009.04.02 20:13 조회 수 : 9 추천:105

sitelink1  
sitelink2  
sitelink3  
sitelink4 http://1 
extra_vars4 ko 
extra_vars5 http://jaures.egloos.com/2263963 
extra_vars6 sitelink1 
prototype은 모든 instance가 공유하는 property라고 생각하면 된다. (다른 언어에서는 마치 class 객체와 같은 형태)

하지만 다른 언어와는 달리 prototype은 runtime 중에 얻어 오거나 또는 변경이 가능하며, 새로 추가하거나 삭제도 가능하다. 모두 runtime 중에 말이다. 

모든 변경에 대한 내역은 해당 작업이 이루어지는 순간 즉시 반영이 되게 되기 때문에, 이미 instance가 생성된 객체에서도 변경한 내용을 바로 사용할 수 있다.

이것이 가능한 일은 Javascript는 컴파일 되지 않고 요청이 있을때마다 동적으로 요청된 property를 찾기 때문인데 다음의 예를 살펴보자.

A 객체가 B의 객체를 상속받는 과정을 생각해 보자. (B.prototype -> A.prototype)
A 객체의 instance가 생성된 a (var a = new A())가 있다고 할때, a의 property를 요청하면 다음과 같은 과정을 거치게 된다.

1. Javascript는 a 객체에서 요청된 property가 해당 객체에 존재 하는지를 확인한다. 찾지 못했다면 다음 과정으로 이동한다.

2. Javascript는 a의 prototype 객체인 "A.prototype"에서 해당 property를 찾는다. 여기서도 찾지 못했다면 다시 다음 과정으로 이동한다.

3. Javascript는 마지막으로 A가 상속받은 "B.prototype"에서 요청된 property를 찾고 해당 property를 return 하게 된다.

이와 같이 각 객체의 prototype에 대한 검색은 요청된 property를 찾기위해 root property까지 계속된다. 이렇게 각 객체마다 연결된 형태를 "prototype chain이라고 한다.

* 참고 : 현재 object에서 property를 찾는 속도는, prototype chain을 통해 검색하는 것보다 약 25%의 빠르다고 한다. 즉, prototype을 통해 상속받은 property가 아닌 현재 object에 존재하는 property를 얻어오는 것이 더 빠르다는 의미이다. - High Performance Ajax Application, p17
    
    
다음과 같은 function A가 있다고 하자.

function A() { ... }

new A() 가 실행되면, 실제로는 2개의 객체가 생성된다. constructor 객체 "A"와 constructor와 연관된 익명의 prototype 객체 "A.prototype".

객체의 instace를 다음과 같이 생성하면,

var a = new A();

Javascript는 instance 객체인 "a"와 constructor의 prototype인 "A.prototype"간에 permanent link를 생성하게 된다. 이건 외부에 노출되지 않는 "private prototype" 이다. 다음의 코드를 통해 이를 확인해 볼수 있다.

Array의 push() 를 재작성 한다고 할때에 다음과 같이 작성한다.

1) Array.prototype.push = function () { ... };

또는 

2) var a = new Array();
    a.constructor.prototype.push = function () { ... }

a.contruct.protype 즉, private prototype을 이용해 상위의 Array.prototype에 접근하고 있다. 1과 2는 동일하다.


번호 제목 글쓴이 날짜 조회 수
237 정규식을 이용한 이메일 검증 스크립트 file 황제낙엽 2023.06.25 0
236 [URLSearchParams] URL 파라미터(매개변수) 값 가져오기 file 황제낙엽 2023.02.02 0
235 (Bard) JavaScript로 JSON 배열을 작성하는 방법 황제낙엽 2023.08.21 0
234 How to build a file upload service with vanilla JavaScript file 황제낙엽 2023.08.22 0
233 (Bard) FileReader 로 여러개의 파일을 read 하는 법 file 황제낙엽 2023.08.23 0
232 json 데이터 내의 변수명에 prefix 로 type 표현하기 황제낙엽 2024.04.15 0
231 CryptoJS 를 이용한 암호화 황제낙엽 2023.02.15 1
230 JSON 클래스가 지원하는 function 황제낙엽 2023.03.31 1
229 체크박스에 체크된 항목 개수 구하기 황제낙엽 2023.06.10 1
228 navigator.mediaDevices 황제낙엽 2023.08.21 1
227 모바일 브라우저에서 file input element 를 이용하여 여러장의 이미지를 서버에 전송하려 할때 황제낙엽 2023.08.21 1
226 현재 document 의 host 와 port 를 얻는 방법 황제낙엽 2023.10.03 1
225 fetch() 함수 사용 예제 file 황제낙엽 2023.11.23 1
224 (Copilot) JSON 객체의 내부 데이터 리스트 길이를 구하는 방법 황제낙엽 2023.03.30 2
223 배열에 대한 루프문 조회 (loop iterator) 황제낙엽 2023.03.01 3
222 (Copilot) 바닐라 스크립트가 뭐지? 황제낙엽 2023.02.24 7
221 Barcode Detection API 황제낙엽 2023.08.06 7
220 Arrow function 황제낙엽 2021.03.07 8
219 client 통신 기술 jquery ajax, fetch, axios 황제낙엽 2021.12.05 8
» [펌] prototype (2) 황제낙엽 2009.04.02 9