摘要:面向?qū)ο缶幊桃欢瓮暾膭?chuàng)建類的示例如何創(chuàng)建一個類,包含有靜態(tài)屬性方法,公有私有屬性方法靜態(tài)私有變量靜態(tài)私有方法安全模式,防止未使用操作符私有變量方法公有屬性,方法靜態(tài)公有屬性靜態(tài)共有方法使用關(guān)閉包定義靜態(tài)私有變量與方法,所有實例創(chuàng)建過程中都
面向?qū)ο缶幊?/b>
一段完整的創(chuàng)建類的示例
// 如何創(chuàng)建一個類,包含有:靜態(tài)屬性方法,公有私有屬性方法? var Book = (function(){ // 靜態(tài)私有變量 var bookNum = 0; // 靜態(tài)私有方法 function checkName(name){} var _book = function(id, newName, newPrice) { // 安全模式,防止未使用new操作符 if(this instanceof _book){ // 私有變量 方法 var name, price; function checkID(){ } // 公有屬性,方法 this.id = id; this.getName = function(){ return name; }; this.getPrice = function(){ return price; }; this.setName = function(name){ name = name; }; this.setPrice = function(price){ price = price; }; console.log(++bookNum); this.setName(newName); this.setPrice(newPrice); } else{ return new _book(id, name, price); } }; _book.prototype = { // 靜態(tài)公有屬性 isJSBook: false, // 靜態(tài)共有方法 displayName: function(){ console.log(this.getName()); } }; return _book; }());
使用關(guān)閉包定義靜態(tài)私有變量與方法,所有實例創(chuàng)建過程中都能訪問到
創(chuàng)建實例時,打印出累加之后的bookNum
當(dāng)替換Book(即_book)的原型之后,之前創(chuàng)建的實例指向的原型并不會改變,之后在之后創(chuàng)建Book實例時運用新的原型
觀察b3、b4的原型
當(dāng)在原來的原型上變更之后,通過該原型創(chuàng)建的實例都能應(yīng)用變更之后的原型
這里定義重復(fù)了,原型上的getPrice方法將會被實例自身擁有的getPrice方法掩蓋住
繼承
方式一:類式繼承: 通過將子類的原型指定為父類的實例
function SuperClass(){ this.superValue = true; } SuperClass.prototype.getSuperValue = function(){ return this.superValue; }; function SubClass(){ this.subValue = true; } SubClass.prototype = new SuperClass(); SubClass.prototype.getSubValue = function(){ return this.subValue;};
缺點:
1、如果父類中存在引用類型屬性,則會被所有子類共用,一個子類修改之后將會影響到所有子類
2、無法在實例化時為父類傳遞初始化參數(shù)
方式二: 構(gòu)造函數(shù)繼承: 在子類構(gòu)造函數(shù)中通過call或者apply調(diào)用父類的構(gòu)造函數(shù),實現(xiàn)繼承父類定義的屬性方法
function SuperClass(id){ this.books = ["js", "css", "html"]; this.id = id; } SuperClass.prototype.showBooks = function(){ console.log(this.books.join()); }; function SubClass(id){ SuperClass.call(this, id); }
缺點:
1、子類沒有繼承父類的原型
2、每個實例化出來的子類對象都會多帶帶擁有一份父類上定義的屬性方法,無法復(fù)用父類的屬性或者方法
方式三: 組合繼承: 方式一與方式二的組合模式
function SuperClass(name){ this.name = name; this.books = ["js", "css","html"]; } SuperClass.prototype.getName = function(){ console.log(this.name); }; function SubClass(name, time){ SuperClass.call(this, name); this.time = time; } SubClass.prototype = new SuperClass(); SubClass.prototype.getTime = function(){ console.log(this.time);}
缺點:
1、父類構(gòu)造函數(shù)執(zhí)行了兩遍
2、子類實例化出來的對象原型中重復(fù)了一次父類構(gòu)造函數(shù)中的屬性方法
方式四: 原型式繼承: 使用過渡函數(shù)作為構(gòu)造函數(shù),傳入的對象作為過渡函數(shù)的原型
function inheritObject(o){ function F(){} F.prototype = o; return new F(); }
缺點:
跟方式一有相同的缺點
方式五: 寄生式繼承: 在方式四的基礎(chǔ)上進(jìn)行二次封
function createBook(obj){ var o = inheritObject(obj); o.getName = function(){ console.log(this.name); }; return o; }
方式六: 寄生組合式繼承: 寄生式繼承跟夠構(gòu)造函數(shù)繼承的組合
function inheritPrototype(SubClass, SuperClass){ var p = inheritObject(SuperClass.prototype); p.constructor = SubClass; SubClass.prototype = p; } function SuperClass(name){ this.name = name; this.books = ["js", "css","html"]; } SuperClass.prototype.getName = function(){ console.log(this.name); }; function SubClass(name, time){ SuperClass.call(this, name); this.time = time; } inheritPrototype(SubClass, SuperClass); SubClass.prototype.getTime = function(){ console.log(this.time); }
子類添加原型方法只能在現(xiàn)有原型上一個添加整個過程:先定義子類及父類與父類原型,然后子類原型引用父類的原型對象,然后子類在添加自己的原型方法,最后調(diào)用父類構(gòu)造函數(shù)
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/96321.html
摘要:看起來沒有集合框架,線程,等那么耀眼,但它可是很多框架的基礎(chǔ)啊回復(fù)反射查看相關(guān)文章,先把基礎(chǔ)學(xué)會,后面的得用到它。 回頭看看, 我進(jìn)入Java 領(lǐng)域已經(jīng)快15個年頭了, 雖然學(xué)的也一般, 但是分享下我的心得,估計也能幫大家少走點彎路。[入門]我在2001年之前是C/C++陣營, 有C和面向?qū)ο蟮幕A(chǔ), 后來轉(zhuǎn)到Java ,發(fā)現(xiàn)沒有指針的Java真是好簡單, 另外Java 的類庫好用的讓...
摘要:項目介紹是一個全新的語言的運行時環(huán)境,基于目前最新的進(jìn)行打造,支持最新的語言規(guī)范,同時提供了自己的運行時標(biāo)準(zhǔn)庫。同樣也在的基礎(chǔ)上進(jìn)行打造,實現(xiàn)了一個除開發(fā)之外的一個全新的運行環(huán)境。發(fā)布核心虛擬機(jī)的鏡像。整合運行時框架。 showImg(https://segmentfault.com/img/bVbnQXK); polarphp 項目介紹 polarphp是一個全新的PHP語言的運行時...
摘要:關(guān)于三者的一些概括總結(jié)離線分析框架,適合離線的復(fù)雜的大數(shù)據(jù)處理內(nèi)存計算框架,適合在線離線快速的大數(shù)據(jù)處理流式計算框架,適合在線的實時的大數(shù)據(jù)處理我是一個以架構(gòu)師為年之內(nèi)目標(biāo)的小小白。 整理自《架構(gòu)解密從分布式到微服務(wù)》第七章——聊聊分布式計算.做了相應(yīng)補充和修改。 [TOC] 前言 不管是網(wǎng)絡(luò)、內(nèi)存、還是存儲的分布式,它們最終目的都是為了實現(xiàn)計算的分布式:數(shù)據(jù)在各個計算機(jī)節(jié)點上流動,同...
閱讀 3524·2021-11-17 17:01
閱讀 3933·2021-11-08 13:12
閱讀 2487·2021-10-08 10:04
閱讀 707·2021-09-29 09:35
閱讀 1429·2021-09-26 10:12
閱讀 2055·2021-09-07 09:58
閱讀 1964·2019-08-30 15:55
閱讀 2142·2019-08-30 13:14