函數:原型
每個構造函數都有一個屬性叫作原型(prototype,下面都再也不翻譯,使用其原文)。這個屬性很是有用:爲一個特定類聲明通用的變量或者函數。
prototype的定義
你不須要顯式地聲明一個prototype屬性,由於在每個構造函數中都有它的存在。你能夠看看下面的例子:
Example PT1
CODE:
function Test()
{
}
alert(Test.prototype); // 輸出 "Object"
給prototype添加屬性
就如你在上面所看到的,prototype是一個對象,所以,你可以給它添加屬性。你添加給prototype的屬性將會成爲使用這個構造函數建立的對象的通用屬性。
例如,我下面有一個數據類型Fish,我想讓全部的魚都有這些屬性:livesIn="water"和price=20;爲了實現這個,我能夠給構造函數Fish的prototype添加那些屬性。
Example PT2
CODE:
function Fish(name, color)
{
this.name=name;
this.color=color;
}
Fish.prototype.livesIn="water";
Fish.prototype.price=20;
接下來讓咱們做幾條魚:
CODE:
var fish1=new Fish("mackarel", "gray");
var fish2=new Fish("goldfish", "orange");
var fish3=new Fish("salmon", "white");
再來看看魚都有哪些屬性:
CODE:
for (var i=1; i<=3; i++)
{
var fish=eval_r("fish"+i); // 我只是取得指向這條魚的指針
alert(fish.name+","+fish.color+","+fish.livesIn+","+fish.price);
}
輸出應該是:
CODE:
"mackarel, gray, water, 20"
"goldfish, orange, water, 20"
"salmon, white water, 20"
你看到全部的魚都有屬性livesIn和price,咱們甚至都沒有爲每一條不一樣的魚特別聲明這些屬性。這時由於當一個對象被建立時,這個構造函數 將會把它的屬性prototype賦給新對象的內部屬性__proto__。這個__proto__被這個對象用來查找它的屬性。
你也能夠經過prototype來給全部對象添加共用的函數。這有一個好處:你不須要每次在構造一個對象的時候建立並初始化這個函數。函數