亚洲中字慕日产2020,大陆极品少妇内射AAAAAA,无码av大香线蕉伊人久久,久久精品国产亚洲av麻豆网站

資訊專欄INFORMATION COLUMN

古老的面向?qū)ο缶幊?

sutaking / 531人閱讀

摘要:面向?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

相關(guān)文章

  • 假如時(shí)光倒流,我會(huì)這么學(xué)習(xí)Java

    摘要:看起來沒有集合框架,線程,等那么耀眼,但它可是很多框架的基礎(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ù)好用的讓...

    bladefury 評(píng)論0 收藏0
  • polarphp:一個(gè)新 PHP 語(yǔ)言運(yùn)行時(shí)環(huán)境

    摘要:項(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í)...

    宋華 評(píng)論0 收藏0
  • 關(guān)于分布式計(jì)算一些概念

    摘要:關(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),同...

    Ververica 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<