JS 원형 객체 만들기 면접 문제

1808 단어
1、
function A(){}

	A.prototype={
	aa:"aa",
	method:function(){}
}
   var a = new A();
   var b = new A();
  
   console.log(a.aa==b.aa); //true
   console.log(a.method==b.method); //true 
   console.log("a.aa="+a.aa+" b.aa="+b.aa) //a.aa=aa b.aa=aa

분석:prototype 원형의 뜻, 이것은 JS 창설 대상 방법 중의 원형법이다.원형법으로 대상을 정의하면 생성된 모든 대상은 원형의 속성을 공유합니다.
원형 방식을 사용하기 때문에 a와 b는 같은 원형을 가리키며 같은 대상 속성에 대응한다.
2、
 function A(){}

	A.prototype={
	aa:"aa",
	method:function(){}
}
   var a = new A();
   var b = new A();
   b.aa = "bb";
   b.method=function(){console.log("b method change")}
   console.log(a.aa==b.aa); //false
   console.log(a.method==b.method); //false 
   console.log("a.aa="+a.aa+" b.aa="+b.aa) //a.aa=aa b.aa=bb
   console.log("a.method="+a.method+" b.method="+b.method) //a.method=function (){} b.method=function (){console.log("b method change")}

분석: a와 b는 같은 원형을 가리킨다. 내 이해는 만약에 실례 대상이 원형의 내용을 수정하면 실례 대상을 기준으로 한다.
3、
function A(){
   	var count = 0;
   	this.aa = "aa";
   	this.method = function(){
   		return count;
   	}
   	this.obj={}
   }
   A.prototype={
   	aa:"cc",
   	method:function(){}
   }
   
   var a = new A;
   var b = new A;
   console.log(a.aa==b.aa); //true
   console.log(a.obj==b.obj); //false
   console.log(a.method==b.method); //false 
   console.log("a.aa="+a.aa+" b.aa="+b.aa); //a.aa=aa b.aa=aa
   console.log("a.method="+a.method+" b.method="+b.method) //a.method=function (){return count;} b.method=function (){return count;}

분석: 이것은 우선순위의 문제입니다. JS는prototype으로 대상을 만들고 우선순위가 있습니다. 구조 방법이 존재하면 먼저 구조 방법을 사용하고 구조 방법이 없으면prototype 방법을 사용합니다.

좋은 웹페이지 즐겨찾기