创建对象的几种方式

1.工厂模式:以函数来封装特定接口创建对象的细节

function createPerson(name,age,job){
   var o=new Object();
   o.name=name;
   o.age=age;
   o.job=job;
   o.sayName=function(){
       alert(this.name);
};
    return o;
}
var person=createPerson("Jone",23,"doctor");

2,构造函数模式:用来创建特定类型的对象。。构造函数始终以一个大写字母开头。

function Person(name,age,job){
   this.name=name;
   this.age=age;
   this.job=job;
   this.sayName=function(){
   alert(this.name);
};
}
var person1=new Person("Jone",23,"Doctor");
}

1与2的不同之处:1)没有显示的创建对象。2)直接的将属性和方法赋予 了this对象。3)没有return语句

3.原型模式:不必再构造函数中定义对象实例的信息,而是可以将这些信息直接添加到原型对象中去。

function Person(){
   Person.prototype.name="Jone";
   Person.prototype.age=23;
   Person.prototype.job="Doctor";
   Person.prototype.sayName=function(){
    alert(this.name);
}
}
var person1=new Person();
person1.sayName();//"Jone"
var person2=new Person();
person2.sayName();//"Jone"
person2.sayName();//"Nicholas"
alert(person1.sayName==person2.sayName);//true

4.组合使用构造函数模式和原型模式

构造函数模式用于定义实例属性,而原型用于定义方法和共享的属性。

function Person(name,age,job){
     this.name=name;
     this.age=age;
     this.job=job;
     this.friends=["Shelby","Count"];
}
Person.prototype={
constructor:Person,
sayName:function(){
  alert(this.name);
}
}
var person1=new Person("Jone",23,"Doctor");
var person2=new Person("Maria",24,"Doctor");
Person.frindes.push("Van");
alert(person1.friends);//shelby,count,Van
alert(person2.friends);//shelby,count
alert(person1.friends===person2.friends)//falses
alert(person.sayName===person2.sayName);//true

5.动态原型模式:检查某个方法是否效,来决定是否需要初始化原型

function Person(name,age,job){
  this.name=name;
  this.age=age;
  this.job=job;
}
if(typeof this.sayName=='function'){
  person.propertype.sayName=function(){
    alert(this.name);
};
}}
var person1=new Person("Jone",23,"Doctor");
person1.sayName();

6.寄生构造函数模式:封装创建对象的代码,然后返回新创建的对象(使用其他模式的情况下,不要使用此模式)

function Person(name,age,job){
  var o=new Object();
      o.name=name;
      o.age=age;
      o.job=job;
      o.sayname=function(){
          alert(this.name);
};
     return o;
}
var person1=new Person("Jone",23,"Doctor");
person1.sayName();

7.稳妥构造函数模式:不设置公共属性,其方法不引用this的对象。

function Person(name,age,job){
 var o=new Object();
 o.name=name;
 o.age=age;
 o.job=job;
 o.sayName=function(){
 alert(name);
}
return o;
}
var person1=Person("Jone",23,"Doctor");
person1.sayName();

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值