不錯的一篇關(guān)于javascript-prototype繼承
更新時間:2007年08月31日 21:21:47 作者:
1.最基本的用法 把ClassA的一個實例賦值給ClassB,
ClassB就繼承了ClassA的所有屬性。
代碼入下:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
2.從原型繼承理論的角度去考慮,
js的原型繼承是引用原型,不是復(fù)制原型,
所以,修改原型會導(dǎo)致所有B的實例的變化。
代碼如下:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
3.然而 子類對象的寫操作只訪問子類對象中成員,
它們之間不會互相影響,因此,
寫是寫子類 讀是讀原型(如果子類中沒有的話)。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
4.每個子類對象都執(zhí)有同一個原型的引用,
所以子類對象中的原型成員實際是同一個。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
5.構(gòu)造子類時 原型的構(gòu)造函數(shù)不會被執(zhí)行
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
6.接下來是致命的,在子類對象中訪問原型的成員對象:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
7.所以 在prototype繼承中 原型類中不能有成員對象! 所有成員必須是值類型數(shù)據(jù)(string也可以)
用prototype繼承有執(zhí)行效率高,不會浪費內(nèi)存,為父類動態(tài)添置方法后子類中馬上可見等的優(yōu)點。
8.prototype繼承是通過把子類的原型對象(prototype)設(shè)置成父類的一個實例來進(jìn)行繼承的。
9.prototype繼承也有四個比較明顯的缺點:
缺點一:父類的構(gòu)造函數(shù)不是像JAVA中那樣在給子類進(jìn)行實例化時執(zhí)行的,而是在設(shè)置繼承的時候執(zhí)行的,并且只執(zhí)行一次。這往往不是我們希望的,特別是父類的構(gòu)造函數(shù)中有一些特殊操作的情況下。
缺點二:由于父類的構(gòu)造函數(shù)不是在子類進(jìn)行實例化時執(zhí)行,在父類的構(gòu)造函數(shù)中設(shè)置的成員變量到了子類中就成了所有實例對象公有的公共變量。由于JavaScript中繼承只發(fā)生在“獲取”屬性的值時,對于屬性的值是String,Number和Boolean這些數(shù)據(jù)本身不能被修改的類型時沒有什么影響。但是Array和Object類型就會有問題。
缺點三:如果父類的構(gòu)造函數(shù)需要參數(shù),我們就沒有辦法了。
缺點四:子類原本的原型對象被替換了,子類本身的constructor屬性就沒有了。在類的實例取它的constructor屬性時,取得的是從父類中繼承的constructor屬性,從而constructor的值是父類而不是子類。
10.可以針對prototype的缺點進(jìn)行改造
比如把它寫成Function對象的一個方法,這樣用的時候方便。
Function.prototype.Extends = function (parentClass)
{
var Bs = new Function();
Bs.prototype = parentClass.prototype;
this.prototype = new Bs();
this.prototype.Super = parentClass;
this.prototype.constructor = this;
}
希望各位 js 高手能把更好的方式介紹給大家
針對第3,6個
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
針對繼承,
Array.prototype 就不能繼承 ClassA,ClassB
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
帶參數(shù)的繼承問題
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
ClassB就繼承了ClassA的所有屬性。
代碼入下:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
2.從原型繼承理論的角度去考慮,
js的原型繼承是引用原型,不是復(fù)制原型,
所以,修改原型會導(dǎo)致所有B的實例的變化。
代碼如下:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
3.然而 子類對象的寫操作只訪問子類對象中成員,
它們之間不會互相影響,因此,
寫是寫子類 讀是讀原型(如果子類中沒有的話)。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
4.每個子類對象都執(zhí)有同一個原型的引用,
所以子類對象中的原型成員實際是同一個。
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
5.構(gòu)造子類時 原型的構(gòu)造函數(shù)不會被執(zhí)行
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
6.接下來是致命的,在子類對象中訪問原型的成員對象:
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
7.所以 在prototype繼承中 原型類中不能有成員對象! 所有成員必須是值類型數(shù)據(jù)(string也可以)
用prototype繼承有執(zhí)行效率高,不會浪費內(nèi)存,為父類動態(tài)添置方法后子類中馬上可見等的優(yōu)點。
8.prototype繼承是通過把子類的原型對象(prototype)設(shè)置成父類的一個實例來進(jìn)行繼承的。
9.prototype繼承也有四個比較明顯的缺點:
缺點一:父類的構(gòu)造函數(shù)不是像JAVA中那樣在給子類進(jìn)行實例化時執(zhí)行的,而是在設(shè)置繼承的時候執(zhí)行的,并且只執(zhí)行一次。這往往不是我們希望的,特別是父類的構(gòu)造函數(shù)中有一些特殊操作的情況下。
缺點二:由于父類的構(gòu)造函數(shù)不是在子類進(jìn)行實例化時執(zhí)行,在父類的構(gòu)造函數(shù)中設(shè)置的成員變量到了子類中就成了所有實例對象公有的公共變量。由于JavaScript中繼承只發(fā)生在“獲取”屬性的值時,對于屬性的值是String,Number和Boolean這些數(shù)據(jù)本身不能被修改的類型時沒有什么影響。但是Array和Object類型就會有問題。
缺點三:如果父類的構(gòu)造函數(shù)需要參數(shù),我們就沒有辦法了。
缺點四:子類原本的原型對象被替換了,子類本身的constructor屬性就沒有了。在類的實例取它的constructor屬性時,取得的是從父類中繼承的constructor屬性,從而constructor的值是父類而不是子類。
10.可以針對prototype的缺點進(jìn)行改造
比如把它寫成Function對象的一個方法,這樣用的時候方便。
Function.prototype.Extends = function (parentClass)
{
var Bs = new Function();
Bs.prototype = parentClass.prototype;
this.prototype = new Bs();
this.prototype.Super = parentClass;
this.prototype.constructor = this;
}
希望各位 js 高手能把更好的方式介紹給大家
針對第3,6個
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
針對繼承,
Array.prototype 就不能繼承 ClassA,ClassB
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
帶參數(shù)的繼承問題
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
相關(guān)文章
Prototype1.5 rc2版指南最后一篇之Position
Prototype1.5 rc2版指南最后一篇之Position...2007-01-01
Prototype Number對象 學(xué)習(xí)
這個對象提供一些操作數(shù)值類型的工具函數(shù)2009-07-07
Prototype Function對象 學(xué)習(xí)
這個對象就是對function的一些擴(kuò)充,最重要的當(dāng)屬bind方法,其中wrap方法也很重要,在類繼承機制里面就是利用wrap方法來調(diào)用父類的同名方法。2009-07-07
Prototype RegExp對象 學(xué)習(xí)
幫助文檔上沒有這個對象,實際上源代碼中這個對象還是有方法的,就1靜態(tài)方法,作用也不是很大,這里簡單說一下,因為以后介紹別的對象時會用到這個RegExp2009-07-07

