最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

七种JS面向对象之创建对象的方法

来源:动视网 责编:小采 时间:2020-11-27 19:58:39
文档

七种JS面向对象之创建对象的方法

七种JS面向对象之创建对象的方法:本文主要和大家详解七种JS面向对象之创建对象,主要以代码的形式和大家分享,希望能帮助到大家。一、工厂模式考虑到ECMAScript中无法创建类,开发人员发明了一种函数,用函数来封装以特定接口创建对象的细节:function createPerson(name,age,
推荐度:
导读七种JS面向对象之创建对象的方法:本文主要和大家详解七种JS面向对象之创建对象,主要以代码的形式和大家分享,希望能帮助到大家。一、工厂模式考虑到ECMAScript中无法创建类,开发人员发明了一种函数,用函数来封装以特定接口创建对象的细节:function createPerson(name,age,


本文主要和大家详解七种JS面向对象之创建对象,主要以代码的形式和大家分享,希望能帮助到大家。

一、工厂模式
考虑到ECMAScript中无法创建类,开发人员发明了一种函数,用函数来封装以特定接口创建对象的细节:

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 person1 = createPerson("Joy",29,"Software Engineer");
var person2 = createPerson("Greg",27,"Doctor");

二、构造函数模式

function Person(name,age,job){ 
 this.name = name; 
 this.age = age; 
 this.job = job; 
 this.sayName = function(){ 
 alert(this.name);
 }
}
var person1 = new Person("Joy",29,"Software Engineer");
var person2 = new Person("Greg",27,"Doctor");
alert(person1.sayName === person2.sayName); //false.每个Person实例都会创建一个功能相同的Function实例

三、原型模式
每创建一个函数都有一个prototype属性,这个属性是一个指针,指向一个对象,而这个对象的用途是包含可以有特定类型共享的属性和方法。使用原型对象的好处就是可以让所有对象实例共享他所包含的属性和方法

function Person(){}
 Person.prototype.name = "Joy";
 Person.prototype.age = 29;
 Person.prototype.job = "Software Engineer";
 Person.prototype..sayName = function(){ 
 alert(this.name)
};
 var person1 = new Person();


四、组合使用构造函数模式和原型模式

 function Person(name,age,job){ 
 this.name = name; 
 this.age = age; 
 this.job = job;
}
 Person.prototype = { 
 sayName:function(){ 
 alert(this.name)
 }
};
 var person1 = new Person("Joy",29,"Software Engineer");
 var person2 = new Person("Greg",27,"Doctor");
 alert(person1.sayName === person2.sayName); //true


五、动态原型模式

 function Person(name,age,job){ 
 this.name = name; 
 this.age = age; 
 this.job = job; 
 if(typeof this.sayName != 'function'){ 
 console.log(this.name); //在下了person1、person2两个实例下只会
输出Joy,不会输出Greg Person.prototype.sayName = function(){ //这里只在sayName()方法不存在的情况下,才会将它添加到原型中。这段代码只会在初次调用构造函数是才会执行。 alert(this.name) } } } var person1 = new Person("Joy",29,"Software Engineer");var person2 = new Person("Greg",27,"Doctor");



六、寄生虫模式

 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("Joy",27,"Software Engineer");


寄生模式返回的对象与构造函数或者与构造函数的原型属性之间没有关系,也就是说,构造函数返回的对象与在构造函数外部创建的对象没有什么不同。为此建议能使用其他模式的情况下不要使用这种模式

七、稳妥构造函数模式
所谓稳妥指的是没有公共属性,而且其方法也不引用this对象。稳妥构造函数遵循与寄生构造函数类似的模式,但有两点不同:一是新创建的对象实例方法不引用this;而是不使用new操作符调用构造函数。

function Person(name,age,job){ 
 var o = new Object(); 
 o.sayName = function(){ 
 alert(name)
 }; 
 return o;
}
var person1 = Person("Joy",29,"Software Engineer");

这样,变量person1中保存的是一个稳妥的对象,而除了sayName()方法外,没有别的方式可以访问其数据成员。即使有其他代码会给这个对啊ing添加方法或数据成员,但也不可能有别的办法访问传入到构造函数中的原始数据。

文档

七种JS面向对象之创建对象的方法

七种JS面向对象之创建对象的方法:本文主要和大家详解七种JS面向对象之创建对象,主要以代码的形式和大家分享,希望能帮助到大家。一、工厂模式考虑到ECMAScript中无法创建类,开发人员发明了一种函数,用函数来封装以特定接口创建对象的细节:function createPerson(name,age,
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top