JS关于创建原型对象的面试题

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方法。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值