Javascript原型设计

时间:2015-12-30 07:48:29

标签: javascript javascript-objects

将方法添加为原型并在构造函数内部定义

之间的区别是什么

例如:介于

之间
function Car( model, year, miles ) {
this.model = model;
this.year = year;
this.miles = miles;
this.toString = function () {
         return this.model + " has done " + this.miles + " miles";
};
}

function Car( model, year, miles ) {
this.model = model;
this.year = year;
this.miles = miles;
}

Car.prototype.toString = function () {
        return this.model + " has done " + this.miles + " miles";
};

1 个答案:

答案 0 :(得分:1)

  1. this.toSting为使用Car构造函数创建的每个新对象添加属性。

  2. Car.prototype是一个单独的对象,其中使用new Car(...)创建的所有对象都继承了属性。由于toString是原型对象的属性,因此所有Car个对象都会继承该属性。

  3. var car = new Car(...);

    通过调用car.toString()来访问它们。

    然而,当进行呼叫时,首先搜索汽车toString属性。如果不存在,则搜索原型toString,然后调用原型。如果两者都不存在,则在链上一直搜索原型原型,直到在基础对象原型上找到toString