亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javaScript面向對象繼承方法經典實現

2019-11-20 22:22:56
字體:
來源:轉載
供稿:網友
JavaScript的出現已經將近20多年了,但是對這個預言的褒貶還是眾說紛紜。很多人都說JavaScript不能算是面向對象的變成語言。但是JavaScript的類型非常松散,也沒有編譯器。這樣一來給了程序員很大的自由,也帶來了一些缺陷。

雖然JavaScript不算是一門面向對象的語言。但是我們可以模仿著其他語言實現面向對象的方式來實現JavaScript的面向編程。

下面是JavaScript教程中非常經典的繼承方法。
復制代碼 代碼如下:

//定義一個Pet對象。通過這一個名稱和數量的腿。
var Pet = function (name,legs) {
this.name = name; //Save ths name and legs values.
this.legs = legs;
};

//創建一個方法,顯示了Pet的名字和數量的腿。
Pet.prototype.getDetails = function () {
return this.name + " has " + this.legs + " legs ";
}

//定義一個Cat對象,繼承從Pet。
var Cat = function (name) {
Pet.call(this,name,4); //調用這個父對象的構造函數
};

//這條線執行繼承從Pet。
Cat.prototype = new Pet();

//增加一個動作方法的貓
Cat.prototype.action = function () {
return "Catch a bird";
};

//創建一個實例petCat的貓。
var petCat = new Cat("felix");

var details = petCat.getDetails();
console.log(details) //"felix has 4 legs".
var action = petCat.action();
console.log(action) //"Catch a bird".
petCat.name = "sylvester"; //改變petCat的名字
petCat.legs = 7; //改變petCat腿的數量
details = petCat.getDetails();
console.log(details) //"sylvester has 7 legs".

上述方法雖然執行起來沒有太大的問題,但是代碼整體風格略顯臃腫,并不很優雅。在外面還是可以對屬性進行修改。這種方法沒有對繼承的屬性進行保護。下面一種方法,省去的new和prototype,利用“函數繼承”的特性實現。
復制代碼 代碼如下:

//定義一個pet對象。通過這一個名稱和數量的腿。
var pet = function (name,legs) {
//創建一個對象that,其中名字是可以改的,但是腿數不可以改,實現了變量私有化。
var that = {
name : name,
getDetails : function () {
return that.name + " has " + legs + " legs ";
}
};

return that;
}

//定義一個cat對象,繼承從pet。
var cat = function (name) {
var that = pet(name,4); //從pet中繼承屬性

//cat中增加一個action的方法。
that.action = function () {
return "Catch a bird";
}

return that;

}

//創建一個petCat2;
var petCat2 = cat("Felix");

var details = petCat2.getDetails();
console.log(details) //"felix has 4 legs".
var action = petCat2.action();
console.log(action) //"Catch a bird".
petCat2.name = "sylvester"; //我們可以改變名字。
petCat2.legs = 7; //但是不可以改變腿的數量
details = petCat2.getDetails();
console.log(details) //"sylvester has 4 legs".

溫馨提示:使用原型繼承的好處是內存效率高,不管它被繼承多少次,對象的原型屬性和方法只被保存一次。函數繼承的時候,每個新的實例都會創建重復的屬性和方法。若創建很多大的對象,內存消耗會很大。解決方法是把較大的屬性或方法保存在一個對象中,并將其作為參數傳給構造函數。這樣所有實例就會使用一個對象資源,而不是創建自己的版本了。

上面兩種方法都可以輕松實現JavaScript面向對象的繼承,沒有哪種方法絕對的好,也沒有哪種方法絕對的不好。依個人情況喜好而定。這兩種方法也不是唯一的,歡迎大家評論補充喲!~
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
一本色道久久88综合日韩精品| 国产不卡在线观看| 欧美成人久久久| 国产精品久久久久久久天堂| 日韩女优人人人人射在线视频| 久久99精品久久久久久噜噜| 成人免费自拍视频| 91大神福利视频在线| 久久久精品中文字幕| 亚洲精选中文字幕| 欧美性色视频在线| 亚洲国产精品人久久电影| 久久视频国产精品免费视频在线| 欧美性猛交xxxxx水多| 成人动漫网站在线观看| 精品久久久免费| 色在人av网站天堂精品| 精品国内自产拍在线观看| 欧美一区视频在线| 日韩一中文字幕| 亚洲一区二区福利| 精品亚洲aⅴ在线观看| 久久精品国产一区二区三区| 亚洲男子天堂网| 亚洲精品在线不卡| 欧美在线不卡区| 国产精品久久久久久久久久尿| 川上优av一区二区线观看| 国产男女猛烈无遮挡91| 亚洲精品aⅴ中文字幕乱码| 91嫩草在线视频| 91精品国产亚洲| 国产一区二区三区在线看| 亚洲美女动态图120秒| 日韩中文在线视频| 国产日韩欧美综合| 国产精品7m视频| 国产精品激情av电影在线观看| 欧美洲成人男女午夜视频| 精品久久国产精品| 日韩免费av一区二区| 日韩av最新在线| 国产成人高清激情视频在线观看| 91青草视频久久| 川上优av一区二区线观看| 中文日韩在线视频| 欧美一区二三区| 97高清免费视频| 久久久91精品| 国内成人精品一区| 日韩av中文字幕在线| 亚洲国产欧美一区二区三区同亚洲| 91亚洲国产成人精品性色| 欧美电影在线观看高清| 亚洲第一综合天堂另类专| 久久综合免费视频影院| 538国产精品视频一区二区| 欧美成人免费小视频| 精品一区二区三区电影| 亚洲精品久久久久久久久久久久久| 中文字幕亚洲欧美日韩2019| 久久久精品999| 久久最新资源网| 国产精品久久久久999| …久久精品99久久香蕉国产| 国产亚洲欧美另类中文| 成人在线视频福利| 97免费中文视频在线观看| 不卡伊人av在线播放| 欧美最猛性xxxxx免费| 国产精品久久久久久搜索| 国内精品小视频在线观看| 欧美极品美女视频网站在线观看免费| 成人一区二区电影| 欧美亚洲视频在线观看| 久久91超碰青草是什么| 国产精品午夜视频| 日韩亚洲精品电影| 欧美日韩一区二区在线播放| 伊人久久久久久久久久久久久| 欧美专区在线视频| 亚洲激情电影中文字幕| 国产精品白丝jk喷水视频一区| 中文国产成人精品久久一| 亚洲第一天堂无码专区| 国产欧美在线视频| 精品小视频在线| 日韩一区二区三区xxxx| 北条麻妃一区二区三区中文字幕| 国产精品国语对白| 国产成人一区三区| 亚洲免费电影一区| 国产日韩欧美中文在线播放| 久久久999精品| 久久av在线播放| 欧美电影免费观看网站| 欧美黄色片在线观看| 亚洲黄色av女优在线观看| 欧美激情一二区| 中文字幕视频在线免费欧美日韩综合在线看| 日本一区二三区好的精华液| 亚洲人成在线电影| 亚洲欧美日韩一区在线| 国产va免费精品高清在线| 日本伊人精品一区二区三区介绍| 日韩精品免费在线视频| 精品久久久久久久久中文字幕| 中文字幕日韩欧美在线| 国产精品爱久久久久久久| 日韩精品999| 国产精品爽爽爽爽爽爽在线观看| 精品成人av一区| 久久久久成人网| 91手机视频在线观看| 日韩电影在线观看永久视频免费网站| 亚洲国产精品va在看黑人| 国产精品∨欧美精品v日韩精品| 日本久久久久久久久久久| 亚洲人成自拍网站| 欧美日韩成人在线播放| 国产丝袜一区二区三区免费视频| 日韩美女在线看| 日韩欧美亚洲成人| 亚洲九九九在线观看| 久久视频免费观看| 岛国av在线不卡| 欧美人成在线视频| 欧美天天综合色影久久精品| 日韩中文字幕国产| 国产精品视频免费观看www| 亚洲r级在线观看| 亚洲午夜激情免费视频| 亚洲一区二区久久久| 成人综合国产精品| 国产aaa精品| 国产综合久久久久久| 亚洲成avwww人| 国产精品男人的天堂| 欧美一级淫片videoshd| 成人免费网站在线观看| 久久在线观看视频| 91干在线观看| 国产精品久久久久久久久久久久久| 日韩av影院在线观看| 日韩精品在线视频| 影音先锋欧美在线资源| 一区二区三区视频在线| 国产亚洲精品成人av久久ww| 亚洲精品久久久久久久久| 九九热精品视频| 久久久久www| 欧美大全免费观看电视剧大泉洋| 亚洲自拍偷拍一区| 午夜精品久久久久久99热软件| 中文字幕视频一区二区在线有码| 欧美国产在线电影| 国产日韩欧美在线| 97免费视频在线| 深夜福利亚洲导航| 欧美中文字幕视频在线观看| 国产精品都在这里| 亚洲精选中文字幕| 中文字幕日韩有码| 国产精品成人aaaaa网站|