1,原型模式创建对象
原型也是一个对象。我们创建的函数都有一个prototype属性,这个属性指向一个对象,这个对象包含有特定函数创建的实例共享的属性和方法。
使用原型对象可以使所有的实例共享属性和方法,而不必再构造函数中初始化属性和方法。
function Person(){
};
Person.prototype.name="qi";
Person.prototype.age=22;
Person.prototype.job="cooder";
var person1=new Person();
var person2=new Person();
console.log(person1.name); //qi
console.log(person2.name); //qi
上面我们把所有的属性都添加到构造函数的prototype上面,构造函数变成了一个空的函数。实例访问到的属性是共享的。
很容易看到原型模式有不足的地方,结果所有实例在默认情况下都将取得相同的属性值。虽然这会在某种程度上带来一些不方便,但还不是原型的最大问题。
当原型上的属性是一个引用类型的时候,会有意想不到的结果。
function Person(){
};
Person.job=["coder","son","parent"];
var person1=new Person();
var Person2=new Person();
person1.job.push("bigV");
console.log(person1.job); //["coder","son","parent","bigV"]
console.log(person2.job); //["coder","son","parent","bigV"]
可以看到我们在person1上修改属性会影响到person2上面的job属性。这显然不是我们想要的。因为person1的job属性和person2的job属性是共享的。