用 Object.create實現(xiàn)類式繼承

下面的例子演示了如何使用Object.create()來實現(xiàn)類式繼承紧憾。這是一個所有版本JavaScript都支持的單繼承稿辙。

// Shape - superclass
function Shape() {
  this.x = 0;
  this.y = 0;
}

// superclass method
Shape.prototype.move = function(x, y) {
  this.x += x;
  this.y += y;
  console.info('Shape moved.');
};

// Rectangle - subclass
function Rectangle() {
  Shape.call(this); // call super constructor.
}

// subclass extends superclass
Rectangle.prototype = Object.create(Shape.prototype);
Rectangle.prototype.constructor = Rectangle;

var rect = new Rectangle();

console.log('Is rect an instance of Rectangle?',
  rect instanceof Rectangle); // true
console.log('Is rect an instance of Shape?',
  rect instanceof Shape); // true
rect.move(1, 1); // Outputs, 'Shape moved.'

如果你希望能繼承到多個對象嘱巾,則可以使用混入的方式。

function MyClass() {
     SuperClass.call(this);
     OtherSuperClass.call(this);
}

// inherit one class
MyClass.prototype = Object.create(SuperClass.prototype);
// mixin another
Object.assign(MyClass.prototype, OtherSuperClass.prototype);
// re-assign constructor
MyClass.prototype.constructor = MyClass;

MyClass.prototype.myMethod = function() {
     // do a thing
};

轉(zhuǎn)自MDN

?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末物咳,一起剝皮案震驚了整個濱河市锣险,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖囱持,帶你破解...
    沈念sama閱讀 206,482評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件夯接,死亡現(xiàn)場離奇詭異,居然都是意外死亡纷妆,警方通過查閱死者的電腦和手機盔几,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評論 2 382
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來掩幢,“玉大人逊拍,你說我怎么就攤上這事〖柿冢” “怎么了芯丧?”我有些...
    開封第一講書人閱讀 152,762評論 0 342
  • 文/不壞的土叔 我叫張陵,是天一觀的道長世曾。 經(jīng)常有香客問我缨恒,道長,這世上最難降的妖魔是什么轮听? 我笑而不...
    開封第一講書人閱讀 55,273評論 1 279
  • 正文 為了忘掉前任骗露,我火速辦了婚禮,結果婚禮上血巍,老公的妹妹穿的比我還像新娘萧锉。我一直安慰自己,他們只是感情好述寡,可當我...
    茶點故事閱讀 64,289評論 5 373
  • 文/花漫 我一把揭開白布柿隙。 她就那樣靜靜地躺著,像睡著了一般鲫凶。 火紅的嫁衣襯著肌膚如雪禀崖。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評論 1 285
  • 那天螟炫,我揣著相機與錄音波附,去河邊找鬼。 笑死不恭,一個胖子當著我的面吹牛叶雹,可吹牛的內(nèi)容都是我干的财饥。 我是一名探鬼主播换吧,決...
    沈念sama閱讀 38,351評論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼钥星!你這毒婦竟也來了沾瓦?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 36,988評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎贯莺,沒想到半個月后风喇,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,476評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡缕探,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,948評論 2 324
  • 正文 我和宋清朗相戀三年魂莫,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片爹耗。...
    茶點故事閱讀 38,064評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡耙考,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出潭兽,到底是詐尸還是另有隱情倦始,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評論 4 323
  • 正文 年R本政府宣布山卦,位于F島的核電站鞋邑,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏账蓉。R本人自食惡果不足惜枚碗,卻給世界環(huán)境...
    茶點故事閱讀 39,261評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望剔猿。 院中可真熱鬧视译,春花似錦、人聲如沸归敬。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽汪茧。三九已至椅亚,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間舱污,已是汗流浹背呀舔。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評論 1 262
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留扩灯,地道東北人媚赖。 一個月前我還...
    沈念sama閱讀 45,511評論 2 354
  • 正文 我出身青樓,卻偏偏與公主長得像珠插,于是被迫代替她去往敵國和親惧磺。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 42,802評論 2 345

推薦閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 171,510評論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統(tǒng)中一些常見模式的工具(例如配置管理捻撑,服務發(fā)現(xiàn)磨隘,斷路器缤底,智...
    卡卡羅2017閱讀 134,599評論 18 139
  • 發(fā)現(xiàn) 關注 消息 iOS 第三方庫、插件番捂、知名博客總結 作者大灰狼的小綿羊哥哥關注 2017.06.26 09:4...
    肇東周閱讀 12,024評論 4 62
  • 對于想要的生活的樣子个唧,我也是隨著時間的推移而慢慢清晰的∩柙ぃ或者說自己過去的渾渾噩噩徙歼,沒有為自己的人生負責,我一直想...
    墨之屋閱讀 239評論 0 3
  • “為你我用了半年的積蓄画恰,漂洋過海地來看你,為了這次相聚吸奴,我連見面時的呼吸都曾反復練習........”還有一個禮拜...
    烏冬蓋飯閱讀 992評論 1 2