摘要:面向對象編程一段完整的創建類的示例如何創建一個類,包含有靜態屬性方法,公有私有屬性方法靜態私有變量靜態私有方法安全模式,防止未使用操作符私有變量方法公有屬性,方法靜態公有屬性靜態共有方法使用關閉包定義靜態私有變量與方法,所有實例創建過程中都
面向對象編程
一段完整的創建類的示例
// 如何創建一個類,包含有:靜態屬性方法,公有私有屬性方法? var Book = (function(){ // 靜態私有變量 var bookNum = 0; // 靜態私有方法 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 = { // 靜態公有屬性 isJSBook: false, // 靜態共有方法 displayName: function(){ console.log(this.getName()); } }; return _book; }());
使用關閉包定義靜態私有變量與方法,所有實例創建過程中都能訪問到
創建實例時,打印出累加之后的bookNum
當替換Book(即_book)的原型之后,之前創建的實例指向的原型并不會改變,之后在之后創建Book實例時運用新的原型
觀察b3、b4的原型
當在原來的原型上變更之后,通過該原型創建的實例都能應用變更之后的原型
這里定義重復了,原型上的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、無法在實例化時為父類傳遞初始化參數
方式二: 構造函數繼承: 在子類構造函數中通過call或者apply調用父類的構造函數,實現繼承父類定義的屬性方法
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、每個實例化出來的子類對象都會多帶帶擁有一份父類上定義的屬性方法,無法復用父類的屬性或者方法
方式三: 組合繼承: 方式一與方式二的組合模式
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、父類構造函數執行了兩遍
2、子類實例化出來的對象原型中重復了一次父類構造函數中的屬性方法
方式四: 原型式繼承: 使用過渡函數作為構造函數,傳入的對象作為過渡函數的原型
function inheritObject(o){ function F(){} F.prototype = o; return new F(); }
缺點:
跟方式一有相同的缺點
方式五: 寄生式繼承: 在方式四的基礎上進行二次封
function createBook(obj){ var o = inheritObject(obj); o.getName = function(){ console.log(this.name); }; return o; }
方式六: 寄生組合式繼承: 寄生式繼承跟夠構造函數繼承的組合
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); }
子類添加原型方法只能在現有原型上一個添加整個過程:先定義子類及父類與父類原型,然后子類原型引用父類的原型對象,然后子類在添加自己的原型方法,最后調用父類構造函數
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/96321.html
摘要:看起來沒有集合框架,線程,等那么耀眼,但它可是很多框架的基礎啊回復反射查看相關文章,先把基礎學會,后面的得用到它。 回頭看看, 我進入Java 領域已經快15個年頭了, 雖然學的也一般, 但是分享下我的心得,估計也能幫大家少走點彎路。[入門]我在2001年之前是C/C++陣營, 有C和面向對象的基礎, 后來轉到Java ,發現沒有指針的Java真是好簡單, 另外Java 的類庫好用的讓...
摘要:項目介紹是一個全新的語言的運行時環境,基于目前最新的進行打造,支持最新的語言規范,同時提供了自己的運行時標準庫。同樣也在的基礎上進行打造,實現了一個除開發之外的一個全新的運行環境。發布核心虛擬機的鏡像。整合運行時框架。 showImg(https://segmentfault.com/img/bVbnQXK); polarphp 項目介紹 polarphp是一個全新的PHP語言的運行時...
摘要:關于三者的一些概括總結離線分析框架,適合離線的復雜的大數據處理內存計算框架,適合在線離線快速的大數據處理流式計算框架,適合在線的實時的大數據處理我是一個以架構師為年之內目標的小小白。 整理自《架構解密從分布式到微服務》第七章——聊聊分布式計算.做了相應補充和修改。 [TOC] 前言 不管是網絡、內存、還是存儲的分布式,它們最終目的都是為了實現計算的分布式:數據在各個計算機節點上流動,同...
閱讀 3514·2021-11-17 17:01
閱讀 3919·2021-11-08 13:12
閱讀 2477·2021-10-08 10:04
閱讀 687·2021-09-29 09:35
閱讀 1418·2021-09-26 10:12
閱讀 2021·2021-09-07 09:58
閱讀 1953·2019-08-30 15:55
閱讀 2134·2019-08-30 13:14