工廠模式設(shè)計(jì)

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>工廠設(shè)計(jì)模式</title>
        
        <!-- 
        @theme: javascript高級(jí) 工廠模式設(shè)計(jì)
        @autor:EthanCoco
        @date:2015-11-21
        @email:lijianlin0204@163.com
        -->
        
        
        
        <script type=text/javascript charset=utf-8>
        //創(chuàng)建一個(gè)命名空間
        var LJL = {};
        
        /**
        *建一個(gè)接口
        *接口需要兩個(gè)參數(shù)
        *參數(shù)1: 接口的名字(string)
        *參數(shù)2: 方法名稱(chēng)(數(shù)組(string))
        */
        LJL.Interface = function(name,methods){
            if(arguments.length !== 2){//判斷接口參數(shù)個(gè)數(shù)是否正確
                throw new Error("參數(shù)個(gè)數(shù)不正確!");
            }
            this.name = name;
            this.methods = [];//定義一個(gè)內(nèi)置的空數(shù)組接受方法名稱(chēng)里的元素
            for(var i = 0;i < methods.length;i++){
                if(typeof methods[i] !== 'string'){
                    throw new Error("方法名稱(chēng)錯(cuò)誤膊夹,必須是字符串類(lèi)型杜顺!");
                }
                //把傳入?yún)?shù)的元素全部放到內(nèi)置的methods中去
                this.methods.push(methods[i]);
            }
            
        };
        
        /**
        *接口靜態(tài)方法
        *參數(shù):object
        *檢驗(yàn)接口里的方法是否實(shí)現(xiàn)
        *如果通過(guò)不做任何操作烘贴,如果不通過(guò),拋出error
        *目的:檢測(cè)方法是否全部實(shí)現(xiàn)
        *object 要求參數(shù)必須有兩個(gè)以上
        *一個(gè)是對(duì)象實(shí)例
        *其它是要檢驗(yàn)的接口對(duì)象
        */
        LJL.Interface.checkMethodsIsPass = function(object){
            if(arguments.length < 2){//判斷參數(shù)蜡歹,如果參數(shù)小于2真友,拋出異常
                throw new Error("要求參數(shù)必須有兩個(gè)以上@param1=實(shí)例對(duì)象,其它參數(shù)是接口對(duì)象富寿!");
            }
            //獲得接口實(shí)例對(duì)象
            for(var i = 1;i<arguments.length;i++){//i=1是因?yàn)榈诙€(gè)參數(shù)是需要檢測(cè)的接口
                var  instanceInterface = arguments[i];
                //判斷參數(shù)是否是接口對(duì)象
                if(instanceInterface.constructor !== LJL.Interface){
                    throw new Error("參數(shù)是不是接口對(duì)象睬隶!");
                }
                //如果是,檢測(cè)接口對(duì)象里的方法是否實(shí)現(xiàn)
                for(var j = 0;j<instanceInterface.methods.length;j++){
                    //用歷史變量接受一個(gè)方法的名稱(chēng)页徐,名稱(chēng)是字符串苏潜,如果不是就拋出error
                    var methodName = instanceInterface.methods[j];
                    //object[key]表示的就是方法
                    //方法是一個(gè)函數(shù),需要判斷
                    if(!object[methodName] || typeof object[methodName] !== 'function'){
                        throw new Error("這個(gè)方法 '" + methodName + "' 找不到变勇!");
                    } 
                }
            
            }
            
        };
        
        /**
         * 繼承方法
         * @param {Object} sub
         * @param {Object} sup
         */            
        LJL.extend=function(sub ,sup){
             // 目的: 實(shí)現(xiàn)只繼承父類(lèi)的原型對(duì)象
             var F = new Function();    // 1 創(chuàng)建一個(gè)空函數(shù)    目的:空函數(shù)進(jìn)行中轉(zhuǎn)
             F.prototype = sup.prototype; // 2 實(shí)現(xiàn)空函數(shù)的原型對(duì)象和超類(lèi)的原型對(duì)象轉(zhuǎn)換
             sub.prototype = new F();     // 3 原型繼承 
             sub.prototype.constructor = sub ; // 4還原子類(lèi)的構(gòu)造器
             //保存一下父類(lèi)的原型對(duì)象: 一方面方便解耦  另一方面方便獲得父類(lèi)的原型對(duì)象
             sub.superClass = sup.prototype; //自定義一個(gè)子類(lèi)的靜態(tài)屬性 接受父類(lèi)的原型對(duì)象
             //判斷父類(lèi)的原型對(duì)象的構(gòu)造器 (加保險(xiǎn))
             if(sup.prototype.constructor == Object.prototype.constructor){
                sup.prototype.constructor = sup ; //手動(dòng)歡迎父類(lèi)原型對(duì)象的構(gòu)造器
             }
        };
        
        
        ////////////////////////////////////////////////
        //以上都是為工廠設(shè)計(jì)模式做必要的準(zhǔn)備
        ////////////////////////////////////////////////
        
        //思路整理
        /**
        *設(shè)計(jì)一個(gè)買(mǎi)電腦的工廠設(shè)計(jì)模式
        *首先恤左,得有一個(gè)“工廠”;
        *其次搀绣,工廠用來(lái)“生產(chǎn)電腦”飞袋;
        *然后,電腦需要“賣(mài)出去”豌熄;
        *繼續(xù)授嘀,賣(mài)出去需要一個(gè)“專(zhuān)賣(mài)店”
        *最后,買(mǎi)電腦的人到什么樣的商店去“買(mǎi)什么樣的電腦”
        */
        
        //生產(chǎn)電腦的工廠 目的:生產(chǎn)電腦
        var PCFactory = {
            //里面有生產(chǎn)電腦的方法
            createPC : function(type){//type 動(dòng)態(tài)生產(chǎn)電腦類(lèi)型锣险,即客戶需要的電腦生產(chǎn)
                //利用eval動(dòng)態(tài)創(chuàng)建傳入類(lèi)型的實(shí)例對(duì)象
                var pc = eval('new '+type+'()');
                //電腦在生產(chǎn)的時(shí)候就需要檢測(cè)是否合格蹄皱!
                //第一個(gè)參數(shù)是電腦的實(shí)例對(duì)象
                //第二個(gè)參數(shù)是接口的實(shí)例對(duì)象
                LJL.Interface.checkMethodsIsPass(pc,PCInterface);
                return pc;
            }
        };
        
        //創(chuàng)建接口實(shí)例對(duì)象
        //接口需要有兩個(gè)參數(shù)
        //一個(gè)是接口的實(shí)例對(duì)象,一個(gè)是方法(數(shù)組),open(開(kāi)機(jī))芯肤,run(運(yùn)行)
        var PCInterface = new LJL.Interface('PCInterface',['open','run']);
        
        //創(chuàng)建一個(gè)電腦的基類(lèi)
        function BasePC(){}
        //在原型對(duì)象上實(shí)現(xiàn)方法
        BasePC.prototype = {
            constructor : BasePC,//還原構(gòu)造器
            open : function(){
                alert(this.constructor.name + "...open");
            },
            run : function(){
                alert(this.constructor.name + "...run");
            }
        };

    
        //電腦有不同的品牌巷折,不同的專(zhuān)賣(mài)店提供不同的電腦
        //創(chuàng)建一個(gè)抽象的基類(lèi)專(zhuān)賣(mài)店
        function PCShop(){}
        PCShop.prototype = {
            constructor : PCShop ,
            //買(mǎi)電腦的方法
            sellPC:function(type){
                this.abstractSellPC(type);
            } ,
            abstractSellPC: function(){
                throw new Error('this method is abstract...');
            }
        };
        
        //創(chuàng)建不同品牌的專(zhuān)門(mén)店
        
        
        
///////////////////////////////////////////////////            
        //戴爾專(zhuān)賣(mài)店
        function DellPCShop(){}
        //每個(gè)店都有賣(mài)電腦的方法,所以我們繼承PCShop里的方法
        LJL.extend(DellPCShop,PCShop);
        //電腦專(zhuān)賣(mài)店有不同型號(hào)的dell電腦
        DellPCShop.prototype = {
            constructor : DellPCShop,
            sellPC : function(type){
                var pc ;
                var pctypes = ['dellx1','dellx5','dellx8'];//所有dell電腦的型號(hào)
                for(i in pctypes){
                    //判斷商店是否有你要的型號(hào)
                    if(pctypes[i] === type){
                        pc = PCFactory.createPC(type);
                        break;
                    }else{
                        throw new Error("沒(méi)有你要的型號(hào)崖咨!");
                    }
                }
                return pc;
            }
        };
        
        //dell電腦不同型號(hào)的方法檢測(cè)實(shí)現(xiàn)
        //檢測(cè)不同品牌的電腦
        function dellx1(){} 
        LJL.extend(dellx1,BasePC); //繼承基類(lèi)的方法
        
        function dellx5(){} 
        LJL.extend(dellx5,BasePC);
        
        function dellx8(){} 
        LJL.extend(dellx8,BasePC);
//////////////////////////////////////////////    



        var shop = new DellPCShop();
        var pc = shop.sellPC('dellx1');
        pc.open();
        </script>
    </head>
    <body>
    </body>
</html>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末锻拘,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子击蹲,更是在濱河造成了極大的恐慌署拟,老刑警劉巖,帶你破解...
    沈念sama閱讀 222,104評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件歌豺,死亡現(xiàn)場(chǎng)離奇詭異推穷,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)类咧,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,816評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門(mén)馒铃,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人痕惋,你說(shuō)我怎么就攤上這事区宇。” “怎么了值戳?”我有些...
    開(kāi)封第一講書(shū)人閱讀 168,697評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵议谷,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我堕虹,道長(zhǎng)卧晓,這世上最難降的妖魔是什么叶洞? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 59,836評(píng)論 1 298
  • 正文 為了忘掉前任,我火速辦了婚禮禀崖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘螟炫。我一直安慰自己波附,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,851評(píng)論 6 397
  • 文/花漫 我一把揭開(kāi)白布昼钻。 她就那樣靜靜地躺著掸屡,像睡著了一般。 火紅的嫁衣襯著肌膚如雪然评。 梳的紋絲不亂的頭發(fā)上仅财,一...
    開(kāi)封第一講書(shū)人閱讀 52,441評(píng)論 1 310
  • 那天,我揣著相機(jī)與錄音碗淌,去河邊找鬼盏求。 笑死,一個(gè)胖子當(dāng)著我的面吹牛亿眠,可吹牛的內(nèi)容都是我干的碎罚。 我是一名探鬼主播,決...
    沈念sama閱讀 40,992評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼纳像,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼荆烈!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起竟趾,我...
    開(kāi)封第一講書(shū)人閱讀 39,899評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤憔购,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后岔帽,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體玫鸟,經(jīng)...
    沈念sama閱讀 46,457評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,529評(píng)論 3 341
  • 正文 我和宋清朗相戀三年山卦,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鞋邑。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,664評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡账蓉,死狀恐怖枚碗,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情铸本,我是刑警寧澤肮雨,帶...
    沈念sama閱讀 36,346評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站箱玷,受9級(jí)特大地震影響怨规,放射性物質(zhì)發(fā)生泄漏陌宿。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,025評(píng)論 3 334
  • 文/蒙蒙 一波丰、第九天 我趴在偏房一處隱蔽的房頂上張望壳坪。 院中可真熱鬧,春花似錦掰烟、人聲如沸爽蝴。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,511評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)蝎亚。三九已至,卻和暖如春先馆,著一層夾襖步出監(jiān)牢的瞬間发框,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,611評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工煤墙, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留梅惯,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 49,081評(píng)論 3 377
  • 正文 我出身青樓番捂,卻偏偏與公主長(zhǎng)得像个唧,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子设预,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,675評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容