亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js對(duì)象的構(gòu)造和繼承實(shí)現(xiàn)代碼

 更新時(shí)間:2010年12月05日 16:12:52   作者:  
js對(duì)象的構(gòu)造和繼承實(shí)現(xiàn)代碼,學(xué)習(xí)javascript面向?qū)ο蟮呐笥芽梢詤⒖枷隆懗龈僚c復(fù)用的代碼。

復(fù)制代碼 代碼如下:

<script>
//定義js的user對(duì)象
function User(name,age){
this.name=name,
this.age=age,
this.getName=function(){
return this.name;
},
this.getAge=function(){
return this.age;
}
}
//實(shí)例化一個(gè)對(duì)象
var use=new User("aa",21);
alert(use.name);
alert(use.getAge());
//js對(duì)象繼承
/*
jb51.net 在面向?qū)ο蟮木幊谭椒ㄖ?,?duì)象繼承是必不可少的,那么怎么在javascript中實(shí)現(xiàn)繼承機(jī)制呢。由于javascript并不是一個(gè)嚴(yán)格的面向?qū)ο蟮恼Z(yǔ)言,因此在對(duì)象繼承上也顯的不一樣。我們也來(lái)創(chuàng)建一個(gè)基類Polygon,代表一個(gè)多邊形,一個(gè)多邊形有個(gè)共同的屬性就是邊數(shù)(sides)和一個(gè)共同的方法計(jì)算面積(getAreas)。這樣我們的這具Polygon類看起來(lái)就像下面這樣定義:
*/
function Polygon(iSides){
this.sides = iSides;
}
Polygon.prototype.getAreas = function(){
return 0;
}
/*
因?yàn)榛惒⒉荒艽_定面積,因此在這里我們返回為0。
接著我們就創(chuàng)建一個(gè)子類Triangle,一個(gè)三角形,顯然這個(gè)三角形是要從多邊形繼承的,因此我們要讓這個(gè)Triangle類繼承Polygon類,并且要覆蓋Polygon類的getAreas方法來(lái)返回三角形的面積。我們來(lái)看下在javascript中的實(shí)現(xiàn):
*/
function Triangle(iBase, iHeight){
Polygon.call(this,3); //在這里我們用Polygon.call()來(lái)調(diào)用Polygon的構(gòu)造函數(shù),并將3作為參數(shù),表示這是一個(gè)三角形,因?yàn)檫吺谴_定的,所以在子類的構(gòu)造函數(shù)中就不需要指定邊了
this.base = iBase; //三角形的底
this.height = iHeight; //三角形的高
}
Triangle.prototype = new Polygon();
Triangle.prototype.getAreas = function(){
return 0.5 * this.base *this.height; //覆蓋基類的getAreas方法,返回三角形的面積
}

/*
參考上面的實(shí)現(xiàn),我們?cè)俣x一個(gè)矩形:
*/
function Rectangle(iWidth, iHeight){
Polygon.call(this,4);
this.width = iWidth;
this.height = iHeight;
}
Rectangle.prototype = new Polygon();
Rectangle.prototype.getAreas = function(){
return this.width * this.height;
}
/*
好了,上面我們定義了一個(gè)基類和兩個(gè)子數(shù),下面我們來(lái)測(cè)試一個(gè)這兩個(gè)子類是否能正常工作:
*/
var t = new Triangle(3,6);
var r = new Rectangle(4,5);
alert(t.getAreas()); //輸出9說(shuō)明正確
alert(r.getAreas()); //輸出20說(shuō)明正確
</script>

相關(guān)文章

最新評(píng)論