本文實例講述了JavaScript繼承定義與用法。分享給大家供大家參考,具體如下:
javascript 繼承 , 老生長談的東西, 大家應該都很熟悉了, 平時工作基本不會直接使用, 這段時間不忙, 所以補習了下相關基礎知識 ,自己動手實踐, 加深理解:
基類定義如下:
// base classfunction Animal(t){ if(typeof t==='string') this.type=t; else { if(t) this.type=t.toString(); else this.type='Animal' } this.speak=function(str) { if(str) console.log(this.type+' said '+str); else throw "please specify what you want to say!"; }}
1. 原型繼承 (javascript 類庫本身基于原型繼承)
String, Number , Boolean 這三大原始類型 我們可以很直接的通過prototype 檢查到他們繼承自Object.
Date, RegExp ,Array 這三應該是間接繼承了Object, 他們的prototype屬性很特殊 :
Date.prototype =Invalid DateRegExp.prototype=/(?:)/Array.prototype=[]
原型繼承代碼如下: (可以看到Mokey 原型鏈上的Animal和Object)
// Monkey : Animal function Monkey(name,age){ this.name=name; this.age=age;}Monkey.prototype=new Animal('Monkey');// Example 01var m=new Monkey('codeMonkey',10); /* Monkey: age: 10 name: "codeMonkey" __proto__: Animal speak: function (str) type: "Monkey" __proto__: Animal constructor: function Animal(t) __proto__: Object */console.log(m.type); // Monkeyconsole.log(m.name); // codeMonkeyconsole.log(m.age); // 10m.speak('hello world') // Monkey said hello world
2. 調用父類構造函數 ( 通過傳遞子類的this指針 , 將原本是父類的公開成員直接添加到了子類中,從子類原型鏈中無法看出繼承關系)
// Human:Animal function Human(id,name){ // call base class's constuctor function Animal.call(this,'Human'); this.id=id; this.name=name;}var h=new Human(1,'leon');/*id: 1name: "leon"speak: function (str)type: "Human" __proto__: Human constructor: function Human(id,name) __proto__: Object*/h.speak('hello world'); // Human said hello world console.log(h.type); // Human
更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》
希望本文所述對大家JavaScript程序設計有所幫助。
新聞熱點
疑難解答