国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

對采用動態原型方式無法展示繼承機制得思考

2019-11-21 00:56:19
字體:
來源:轉載
供稿:網友
復制代碼 代碼如下:

<script type="text/javascript">
function Polygon(iSides) {
this.sides = iSides;
if(typeof Polygon._initialized == "undefined") {
Polygon.prototype.getArea = function() {
return 0;
};
Polygon._initialized = true;
}
}
function Triangle(iBase,iHeight) {
Polygon.call(this,3);
this.base = iBase;
this.hei = iHeight;
if(typeof Triangle._initialized == "undefined") {
Triangle.prototype = new Polygon();
Triangle.prototype.getArea = function() {
return this.base * this.hei * 0.5;
};
Triangle._initialized = true;
}
}
var oTriangle1 = new Triangle(12,4);
alert(oTriangle1.sides);
//alert(oTriangle1.getArea());
//這句代碼是無法運行的。FireBug顯示oTriangle1.getArea()不是一個function


</script>



  剛開始琢磨這段代碼是很奇怪,為什么不能運行呢?于是我就開始結合作者的敘述思考(作者在這段代碼后面的解釋很繞,不多看幾遍是理解不了他在說什么的),最后終于被我想通了。
  我們已經知道,用var anObject = new aFunction()形式創建對象的過程實際上可以分為3步:
  (1)建立新對象
  (2)將該對象內置的prototype對象設置為構造函數portotype引用的那個原型對象
  (3)將該對象作為this參數調用構造函數,完成成員設置等初始化工作

  請大家注意第(2)步,原來,
復制代碼 代碼如下:

var oTriangle1 = new Triangle(12,4);


  這句執行時,內部執行oTriangle1.prototype = Triangle.prototype;(當然,此時Triangle.prototype對象本身也沒什么實際屬性和方法) 然后才繼續執行直到第(3)步,運行函數體,第一次運行到

復制代碼 代碼如下:

Triangle.prototype = new Polygon();


但這句執行完后,oTriangle1.prototype卻已經無法再賦值了(即執行不到oTriangle1.prototype = Triangle.prototype;),接下來程序執行
復制代碼 代碼如下:

Triangle.prototype.getArea = function() {
return this.base * this.hei * 0.5;
};

但此時卻是為時已晚,oTriangle1.prototype對象是不會擁有該方法的,擁有該方法的只能是剛才new Polygon()創建的對象,于是就有了程序最后一行注釋的結果了。但是接下來創建的Triangle對象卻能正常運行了。請看下面代碼:

代碼
復制代碼 代碼如下:

<script type="text/javascript">
function Polygon(iSides) {
this.sides = iSides;
if(typeof Polygon._initialized == "undefined") {
Polygon.prototype.getArea = function() {
return 0;
};
Polygon._initialized = true;
}
}
function Triangle(iBase,iHeight) {
Polygon.call(this,3);
this.base = iBase;
this.hei = iHeight;
if(typeof Triangle._initialized == "undefined") {
Triangle.prototype = new Polygon();
Triangle.prototype.getArea = function() {
return this.base * this.hei * 0.5;
};
Triangle._initialized = true;
}
}
var oTriangle1 = new Triangle(12,4);
alert(oTriangle1.sides);
//alert(oTriangle1.getArea());
//這句代碼是無法運行的。FireBug顯示oTriangle1.getArea()不是一個function
var oTriangle2 = new Triangle(10,5);
alert(oTriangle2.sides);
//程序最終運行證明了我的理解是正確的。
alert(oTriangle2.getArea());
</script>



至于原因嘛,也就是我前面分析的,此時內部執行oTriangle2.prototype=Triangle.prototype;該原型對象被賦予了有實際屬性和方法的對象引用。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 宁国市| 加查县| 武陟县| 台南县| 霍州市| 遂平县| 滕州市| 岳池县| 梁河县| 德惠市| 彭山县| 临沧市| 周至县| 来凤县| 古田县| 霸州市| 崇州市| 威宁| 枣庄市| 林芝县| 普兰店市| 揭西县| 莱州市| 浠水县| 隆尧县| 布尔津县| 越西县| 疏勒县| 石景山区| 靖边县| 社旗县| 富宁县| 武威市| 临湘市| 北流市| 措美县| 青岛市| 双鸭山市| 长春市| 静海县| 新乡市|