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