天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

JavaScript 原型與繼承說明

function A(x)
{
this.x = x;
}
alert(A.prototype);
alert(A.prototype.constructor);
根據彈出的結果,我們可以得到:原型對象是由函數的構造函數創建,它所擁有的屬性能被所有對象共享,初始時原型對象指向一個Object對象,并且定義了一個constructor屬性,該屬性指向定義該原型對象的構造函數本身,再看如下代碼。

Code
function A(x)
{
A.prototype.x = x;
}
var obj = new A(10);
alert(obj.x);
alert(obj.constructor);
因為原型對象的所有屬性能被構造函數創建對象共享,所以創建的對象可以訪問這里的constructor屬性,同時obj對應的就是原型對象(prototype)所創建出來的一個實例,那么重寫constructor屬性會出現什么樣的結果呢?

Code
function A(x)
{
A.prototype.x = x;
}

var objA = new A(10);
objA.constructor = function(x){ alert("重寫obj的constructor屬性");this.x = 20 };
objA.constructor();
alert(objA.x);

var objB = new A(10);
alert(objB.x);
根據結果我們可以看到,首先彈出的是“重寫obj的constructor屬性”,然后彈出20,在彈出10,可見,我們在書寫重寫objA這個對象的constructor之后,objB并沒有被改變,因此無論在一個對象加入或修改多少屬性這都不影響其原型對象中屬性的本來面目,其實很容易理解js為什么這樣做,因為一個對象的行為不能影響到其他對象,否則將會造成混亂。

在這里,我們可以總結一下,上面代碼的規則:

1.當我們調用某個對象的時候,首先檢查該對象本身的自己定義的屬性,如果存在則調用。

2.當自己本身的屬性不存在的時候,則調用其構造函數所定義的原型對象的引用。

那么根據這個規則,就形成了JavaScript中的一個原型鏈,我們就可以根據這個規則來定義繼承關系。
復制代碼 代碼如下:
function A(x)
{
A.prototype.x = x;
}

function B(x,y)
{
B.prototype.y = y;
A.call(this,x);
}

這段代碼顯示了兩個函數,B函數繼承與A函數,A.call(this.x)表示,將B的對象this傳遞到A函數中進行執行。然后,我們同樣需要由B函數構造出來的對象需要包含A函數的所有特性,因此需要加上這么一句話。
復制代碼 代碼如下:
B.prototype = new A();
alert(B.prototype.constructor);

先我們指定B的原型為A,因此,B函數繼承了A函數的特性,根據彈出的結果,我們可以看到,其constructor指向的是A函數,那么我們的B函數的特性是不是丟失了呢?因此,我們需要在加上一句話,最后給出繼續的整合代碼。
復制代碼 代碼如下:
function A(x)
{
A.prototype.x = x;
A.prototype.ShowA = function(){ alert("A的Show方法!"); };
}

function B(x,y)
{
B.prototype.y = y;
A.call(this,x);
B.prototype.ShowB = function(){ alert("B的Show方法!"); };
}

B.prototype = new A();
B.prototype.constructor = B;

var obj = new B(10,5);
alert(obj.x);
alert(obj.y);
obj.ShowA();
obj.ShowB();

若有疑問或不正之處,歡迎提出指正和討論。

JavaScript技術JavaScript 原型與繼承說明,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 亚洲卫视论坛 | 欧美日韩视频一区二区三区 | 亚色九九九全国免费视频 | 7m凹凸国产刺激在线视频 | 亚洲国产日韩a精品乱码 | 色99久久久久高潮综合影院 | 超碰人热人人热人人看 | 肉多的小说腐小说 | 女人精69xxxxx| 性xxx免费| 999视频精品全部免费观看 | 久久re6热在线视频精品66 | 日本女人水多 | 亚洲欧美日韩一级特黄在线 | 中文字幕国产视频 | 精品午夜久久福利大片免费 | 丁香成人网址 | 国产精品一国产精品免费 | 亚洲成人黄色在线 | 97人妻AV天天澡夜夜爽 | 一级毛片免费视频网站 | 婷婷四房播客五月天 | jazzjazzjazz欧美 | 姉调无修版ova国语版 | 精品无码国产污污污免费网站2 | 国产亚洲一区在线 | 欧美xxx性 | www色视频在线观看 WWW色视频片内射 | 国产欧美另类久久久品 | 国产人妻人伦精品熟女麻豆 | 精品国产国产综合精品 | 777EY_卡通动漫_1页 | 欧美AAAAAA级午夜福利视频 | 国产亚洲精品V在线观看一 国产亚洲精品a在线观看app | 久久re这里视频精品15 | 伊人久久亚洲综合天堂 | 久久天堂成人影院 | 国产亚洲精品久久无码98 | 亚洲精品在看在线观看 | 免费被靠视频动漫 | 久久永久影院免费 |