淺析JS原型繼承與類的繼承
更新時(shí)間:2016年04月07日 15:43:22 投稿:jingxian
下面小編就為大家?guī)硪黄獪\析JS原型繼承與類的繼承。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
我們先看JS類的繼承
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>JS類的繼承</title> </head> <body> /* -- 類式繼承 -- */ <script type="text/javascript"> //先聲明一個(gè)超類 var Animal = function(name) { this.name = name; } //給這個(gè)超類的原型對象上添加方法 Animal.prototype.Eat = function() { console.log(this.name + " Eat"); }; //實(shí)例化這個(gè)超 var a = new Animal("Animal"); //再創(chuàng)建構(gòu)造函數(shù)對象類 var Cat = function(name, sex) { //這個(gè)類中要調(diào)用超類Animal的構(gòu)造函數(shù),并將參數(shù)name傳給它 Animal.call(this, name); this.sex = sex; } //這個(gè)子類的原型對象等于超類的實(shí)例 Cat.prototype = new Animal(); //因?yàn)樽宇惖脑蛯ο蟮扔诔惖膶?shí)例,所以prototype.constructor這個(gè)方法也等于超類構(gòu)造函數(shù) console.log(Cat.prototype.constructor); //這個(gè)是Animal超類的引用,所以要從新賦值為自己本身 Cat.prototype.constructor = Cat; console.log(Cat.prototype.constructor); //子類本身添加了getSex 方法 Cat.prototype.getSex = function() { return this.sex; } //實(shí)例化這個(gè)子類 var _m = new Cat('cat', 'male'); //自身的方法 console.log(_m.getSex()); //male //繼承超類的方法 console.log(_m.Eat()); //cat </script> </body> </html>
我們再看JS原型繼承
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>JS原型繼承</title> </head> <body> <!--原型繼承--> <script type="text/javascript"> //clone()函數(shù)用來創(chuàng)建新的類Person對象 var clone = function(obj) { var _f = function() {}; //這句是原型式繼承最核心的地方,函數(shù)的原型對象為對象字面量 _f.prototype = obj; return new _f; } //先聲明一個(gè)對象字面量 var Animal = { somthing: 'apple', eat: function() { console.log("eat " + this.somthing); } } //不需要定義一個(gè)Person的子類,只要執(zhí)行一次克隆即可 var Cat = clone(Animal); //可以直接獲得Person提供的默認(rèn)值,也可以添加或者修改屬性和方法 console.log(Cat.eat()); Cat.somthing = 'orange'; console.log(Cat.eat()); //聲明子類,執(zhí)行一次克隆即可 var Someone = clone(Cat); </script> </body> </html>
我們可以試驗(yàn)一下,JS類的繼承 children.constructor==father 返回的是true,而原型繼承children.constructor==father 返回的是false;
以上這篇淺析JS原型繼承與類的繼承就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- 在JavaScript中模擬類(class)及類的繼承關(guān)系
- Javascript 類的繼承實(shí)現(xiàn)代碼
- 老生常談 關(guān)于JavaScript的類的繼承
- JS繼承--原型鏈繼承和類式繼承
- JavaScript 高級篇之閉包、模擬類,繼承(五)
- js中實(shí)現(xiàn)多態(tài)采用和繼承類似的方法
- javascript中最常用的繼承模式 組合繼承
- JS 面向?qū)ο笾^承---多種組合繼承詳解
- [js高手之路]從原型鏈開始圖解繼承到組合繼承的產(chǎn)生詳解
- JS繼承之借用構(gòu)造函數(shù)繼承和組合繼承
- JavaScript類的繼承方法小結(jié)【組合繼承分析】
相關(guān)文章
Javascript中 關(guān)于prototype屬性實(shí)現(xiàn)繼承的原理圖
Javascript中關(guān)于prototype屬性實(shí)現(xiàn)繼承的原理圖2013-04-04使用JavaScript 實(shí)現(xiàn)各種跨域的方法
本篇文章是對在JavaScript中實(shí)現(xiàn)各種跨域方法的介紹。需要的朋友參考下2013-05-05Google Dart編程語法和基本類型學(xué)習(xí)教程
Dart編程語言是一個(gè)完全面向?qū)ο蟮恼Z言,包括基礎(chǔ)類型如int變量也都是對象,本文主要介紹了Google Dart編程語法和基本類型2013-11-11