Home  >  Article  >  Web Front-end  >  Detailed explanation of how JavaScript uses factory mode, constructor mode, and prototype mode to create object instances

Detailed explanation of how JavaScript uses factory mode, constructor mode, and prototype mode to create object instances

伊谢尔伦
伊谢尔伦Original
2017-07-26 10:38:361508browse

Although it is very convenient to create an object using the Object constructor or using object literals, this method has an obvious disadvantage: using an interface to create multiple objects will produce a lot of redundant code. . Therefore, in order to solve this problem, people began to use the following methods to common objects.

Factory pattern

This pattern abstracts the specific process of creating objects and uses functions to create the details of objects with specific interfaces


 function cPerson(name,sex,age){
 var o = new Object();
 o.name = name;
 o.sex = sex;
 o.age = age;
 o.show = function(){
 console.log(this.name,this.age,this.sex);
 }
 return o;
}
 var p1 = cPerson('龙','男','100');
 p1.show();
 var p2 = cPerson('田','女','14');
 p2.show();

Factory mode test

Problems with the factory method: Using the factory mode can create an object containing all information, and this function can be called countless times. Although it solves the problem of creating multiple similar objects, it does not solve the problem of object identification (that is, how to know the type of an object)

Constructor Pattern


function CPerson(name,sex,age) {//注意这里 构造函数首字母大写
 this.name = name;
 this.sex = sex;
 this.age = age;
 this.show = function () {
 console.log(this.name, this.age, this.sex);
 }
}
var p1 = new CPerson('龙','男','100');
 p1.show();
var p2 = new CPerson('田','女','14');
 p2.show();

Constructor pattern test

Note that the constructor is slightly different from the factory pattern, as follows

The first letter of the constructor is capitalized

The object is not created explicitly

The properties and methods are assigned to this object

There is no return statement

And the constructor is called in this way The function will roughly go through several steps

Create a new object

Assign the scope of the constructor to this object (so this points to this object)

Execute the code in the constructor (that is, the process of adding properties and methods to a new object)

Return the object

Note: The constructor is actually not much different from an ordinary function, the only difference The difference lies in the calling method. The following demonstrates several different calling methods


 // 调用方式1 new 方式
 var p1 = new CPerson('龙','男','100');
 p1.show();//龙 100 男
 // 调用方式2 普通函数调用
 CPerson('龙','男','100');
 window.show()//龙 100 男 注意属性和方法会被设置到window对象上
 // 调用方式3 在另一个对象的作用域中调用
 var obj = new Object();
 CPerson.call(obj,'龙','男','100');
 obj.show(); //龙 100 男 在obj的作用域

Problems with constructors: The main problem with using constructors is that each method must be recreated on each instance , both p1 and p2 have show methods, but they are not instances of the same Function, because function is also an object in js. Therefore, their shared show methods are not equal.

Prototype pattern

Each function has a prototype attribute, which is a pointer pointing to an object. The purpose of this object is to contain properties and methods that can be shared by all instances of a specific type. That is, the prototype object of the object created by calling the constructor

The advantage is that all instances of the object can share its attributes. That is, there is no need to define the instance information in the constructor


 function CPerson(){
}
CPerson.prototype.name='龙';
CPerson.prototype.sex='男';
CPerson.prototype.age=100;
CPerson.prototype.show=function(){
 console.log(this.name, this.age, this.sex);
}
var p1 = new CPerson();
 p1.show(); //龙 100 男
var p2 = new CPerson();
 p2.show();//龙 100 男
 console.log(p1.show == p2.show)//true

The above is the detailed content of Detailed explanation of how JavaScript uses factory mode, constructor mode, and prototype mode to create object instances. For more information, please follow other related articles on the PHP Chinese website!

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn