日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

JavaScript組合設(shè)計(jì)模式--改進(jìn)引入案例分析

瀏覽:122日期:2023-10-25 14:37:15

本文實(shí)例講述了JavaScript組合設(shè)計(jì)模式--改進(jìn)引入案例。分享給大家供大家參考,具體如下:

對(duì)于組合設(shè)計(jì)模式:

(1)組合模式中把對(duì)象分為兩種(組合對(duì)象,和葉子對(duì)象) (2)組合對(duì)象和葉子對(duì)象實(shí)現(xiàn):同一批操作 (3)對(duì)組合對(duì)象執(zhí)行的操作可以向下傳遞到葉子節(jié)點(diǎn)進(jìn)行操作 (4)這樣就會(huì)弱化類與類之間的耦合 (5)他常用的手法是把對(duì)象組合成屬性結(jié)構(gòu)的對(duì)象

根據(jù)組合模式的這些特性我們改寫代碼如下:

由于用到了接口檢驗(yàn)所以我們先引入接口文件代碼

//定義一個(gè)靜態(tài)方法來實(shí)現(xiàn)接口與實(shí)現(xiàn)類的直接檢驗(yàn)//靜態(tài)方法不要寫出Interface.prototype ,因?yàn)檫@是寫到接口的原型鏈上的//我們要把靜態(tài)的函數(shù)直接寫到類層次上//定義一個(gè)接口類var Interface=function (name,methods) {//name:接口名字 if(arguments.length<2){ alert('必須是兩個(gè)參數(shù)') } this.name=name; this.methods=[];//定義一個(gè)空數(shù)組裝載函數(shù)名 for(var i=0;i<methods.length;i++){ if(typeof methods[i]!='string'){ alert('函數(shù)名必須是字符串類型'); }else { this.methods.push( methods[i]); } }};Interface.ensureImplement=function (object) { if(arguments.length<2){ throw new Error('參數(shù)必須不少于2個(gè)') return false; } for(var i=1;i<arguments.length;i++){ var inter=arguments[i]; //如果是接口就必須是Interface類型 if(inter.constructor!=Interface){ throw new Error('如果是接口類的話,就必須是Interface類型'); } //判斷接口中的方法是否全部實(shí)現(xiàn) //遍歷函數(shù)集合 for(var j=0;j<inter.methods.length;j++){ var method=inter.methods[j];//接口中所有函數(shù) //object[method]傳入的函數(shù) //最終是判斷傳入的函數(shù)是否與接口中所用函數(shù)匹配 if(!object[method]||typeof object[method]!='function' ){//實(shí)現(xiàn)類中必須有方法名字與接口中所用方法名相同throw new Error('實(shí)現(xiàn)類中沒有完全實(shí)現(xiàn)接口中的所有方法') } } }}

(1)統(tǒng)一接口

var composite=new Interface('composite',['getChildByName','add']);//側(cè)重點(diǎn)獲取子var student=new Interface('composite',['goToClass','finishClass']);//側(cè)重點(diǎn)為每個(gè)對(duì)象的實(shí)現(xiàn)

(2)定義組合類

var compositeObj=function (name) { this.name=name; this.type='com';//默認(rèn)是組合類 var childs=new Array();//得到相關(guān)的所有孩子節(jié)點(diǎn) this.getChildByName=function (name) { //涉及到遞歸 var toChilds=new Array(); if(!name){ for(var i=0;i<childs.length;i++){if(childs[i].type=='com'){ toChilds=toChilds.concat(childs[i].getChildByName())}else { toChilds.push(childs[i]);} } }else { for (var i = 0; i < childs.length; i++){ if(childs[i].name==name){ if(childs[i].type=='com'){ toChilds=toChilds.concat(childs[i].getChildByName()); break; }else { toChilds.push(childs[i]); break; } }else { if(childs[i].type == 'com'){ toChilds =toChilds.concat(childs[i].getChildByName(name)); } } } } return toChilds; }; //增加子節(jié)點(diǎn) this.add=function (child) { childs.push(child); return this; }; //去上課this.goToClass=function (name) {var toChilds=this.getChildByName(name); for(var i=0;i<toChilds.length;i++){ toChilds[i].goToClass(); } }; //下課 this.finishClass=function (name) { var toChilds=this.getChildByName(name); for(var i=0;i<toChilds.length;i++){toChilds[i].finishClass(); } }; Interface.ensureImplement(this,composite,student); };

(3)定義葉子類

var studentObj=function (name) { this.name=name; this.type='student';//默認(rèn)是葉子 //得到所有孩子節(jié)點(diǎn) this.getChildByName=function (name) { if(this.name==name){ return this; }else { return null; } } //增加子節(jié)點(diǎn) this.add=function (child) { throw new Error('add 不成被初始化(在葉子了中)') } //去上課 this.goToClass = function(name){ document.write(this.name +' 去上課<br>'); } //下課 this.finishClass = function(name){ document.write(this.name +' 下課<br>'); } Interface.ensureImplement(this,composite,student); }

(4)應(yīng)用---將學(xué)校,班級(jí),組,學(xué)生關(guān)聯(lián)起來

var astudent=new studentObj('我是a同學(xué)'); var bstudent=new studentObj('我是b同學(xué)'); var cstudent=new studentObj('我是c同學(xué)'); var dstudent=new studentObj('我是d同學(xué)'); var estudent=new studentObj('我是e同學(xué)'); var fstudent=new studentObj('我是f同學(xué)'); var gstudent=new studentObj('我是g同學(xué)'); var hstudent=new studentObj('我是h同學(xué)'); var istudent=new studentObj('我是i同學(xué)'); var one = new compositeObj('一班'); var oneOne = new compositeObj('一班一組'); oneOne.add(astudent).add(bstudent); var oneTwo = new compositeObj('一班二組'); oneTwo.add(cstudent).add(dstudent); one.add(oneOne).add(oneTwo); var two = new compositeObj('二班'); var twoOne = new compositeObj('二班一組'); twoOne.add(estudent).add(fstudent); var twoTwo = new compositeObj('二班二組'); twoTwo.add(gstudent).add(hstudent).add(istudent) two.add(twoOne).add(twoTwo); var usPcat = new compositeObj('組合設(shè)計(jì)模式培訓(xùn)學(xué)校'); usPcat.add(one).add(two);

(5)客戶端調(diào)用API,只需要簡(jiǎn)單的安排去上課即可,也就是客戶端只需要寫去上課的代碼即可

usPcat.goToClass();document.write('-------------------------<br>');usPcat.goToClass('一班');document.write('-------------------------<br>');usPcat.goToClass('二班一組');

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運(yùn)行工具:http://tools.jb51.net/code/HtmlJsRun測(cè)試上述代碼運(yùn)行效果。

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

標(biāo)簽: JavaScript
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久午夜精品| 欧美日韩国产精品一区二区亚洲| 九九精品调教| 亚洲永久av| 日韩国产精品久久久| 夜久久久久久| 夜夜嗨网站十八久久| 麻豆9191精品国产| 老司机久久99久久精品播放免费| 欧美女激情福利| 99国产精品| 国产综合欧美| 国产精品免费不| 成人美女视频| 国产综合欧美| 国产乱码精品| 婷婷色综合网| 国产免费久久| 激情欧美国产欧美| 蜜臀久久99精品久久久久久9 | 国产美女高潮在线| 久久精品国语| 日韩av影院| 亚洲免费高清| 国产精品videossex| 女人天堂亚洲aⅴ在线观看| 欧美一区成人| 六月婷婷一区| 欧美成人高清| 91欧美日韩| 国产日韩在线观看视频| 波多野结衣一区| 久久99青青| 99精品视频在线| 国产精品一区免费在线| 日韩视频久久| 精品中国亚洲| 中文字幕日韩欧美精品高清在线| 国产精品精品| 欧美日一区二区三区在线观看国产免| 国产精品99久久精品| 亚欧洲精品视频在线观看| 成人va天堂| 国产欧美一区二区三区米奇| 欧美另类综合| 精品捆绑调教一区二区三区| 欧美一区二区三区久久精品| 国产精品av久久久久久麻豆网| 亚洲久久视频| 亚洲欧美日韩综合国产aⅴ| 日韩综合在线| 欧美国产日韩电影| 日韩精品亚洲aⅴ在线影院| 欧美 日韩 国产一区二区在线视频| 国产欧美在线| 欧美日本久久| 日本午夜精品久久久| 蜜桃视频一区二区| 好看的亚洲午夜视频在线| 亚洲午夜在线| 日韩精品欧美| 日韩一区二区三区在线免费观看| 精品三级av| 国产视频网站一区二区三区| 日韩激情一二三区| 日韩精品成人| 国产亚洲精品美女久久 | 欧美成人精品午夜一区二区| 欧美亚洲免费| 国产精品毛片aⅴ一区二区三区| 日韩视频一二区| 日韩一区二区三区四区五区| 伊人久久一区| 快she精品国产999| 亚洲一级淫片| 欧美视频一区| 高清av一区| 久久精品av| 亚洲无线观看| 911精品国产| 国产aa精品| 蜜桃tv一区二区三区| 一区免费视频| 国产亚洲字幕| 成人日韩在线| 美女精品网站| 国产精品分类| 久久视频一区| 亚洲在线一区| 久久影院一区二区三区| 日韩精品免费一区二区在线观看| 亚洲一区久久| 久久gogo国模啪啪裸体| 欧美色图一区| 日韩av一二三| 91精品啪在线观看国产18| 亚洲影院天堂中文av色| 国产精品第一| aa亚洲婷婷| jizzjizz中国精品麻豆| 亚洲专区视频| 欧美sm一区| 97精品久久| 久久视频一区| 精品国产网站| 色综合视频一区二区三区日韩| 一区二区三区四区日本视频| 亚洲丝袜啪啪| 国产高清久久| 蜜臀国产一区| 国产精品夜夜夜| 亚洲色图国产| 亚洲欧洲一区| 色婷婷精品视频| www.51av欧美视频| 国产精品久久| 久久国产三级| 欧美亚洲三级| 亚洲开心激情| 蜜桃一区二区三区在线| 国产精品试看| 亚洲激情社区| 91久久久精品国产| 亚洲精品一区三区三区在线观看| 久久精品二区亚洲w码 | 偷拍精品精品一区二区三区| 欧美精品二区| 国产免费久久| 日韩激情网站| 亚洲精品免费观看| 久久av一区| 日韩中文欧美在线| 在线日韩中文| 99日韩精品| 玖玖玖国产精品| 亚洲欧美网站在线观看| 国产欧美日韩一区二区三区四区| 91伊人久久| 国产日韩欧美| 免费一区二区三区在线视频| 欧美激情麻豆| 不卡福利视频| 国产伊人精品| 久久先锋影音| 日本不卡中文字幕| 欧美激情福利| 日韩在线观看| 桃色一区二区| 伊人成人网在线看| 综合欧美精品| 国产精品久久久久av蜜臀| 成人日韩av| 美女少妇全过程你懂的久久| 亚洲精品2区| 国产探花一区二区| 日本а中文在线天堂| 狠狠爱成人网| 国产探花在线精品一区二区| 裤袜国产欧美精品一区| 国产精品美女| 精品视频久久| 免费中文字幕日韩欧美| 美国三级日本三级久久99 | 久久人人精品| 天堂精品久久久久| 国产一区国产二区国产三区 | 欧美+日本+国产+在线a∨观看| 午夜精品一区二区三区国产| 久热re这里精品视频在线6| 日韩高清在线不卡| 欧美精品1区| 国产美女一区| 久久精品国产亚洲aⅴ| 精品中文字幕一区二区三区av| 国产欧美综合一区二区三区| 久久精品影视| 国产探花在线精品| 亚洲精品在线影院| 国产精品66| 亚洲综合精品四区| 欧美aaaaaa午夜精品| 欧美+亚洲+精品+三区| 国产视频一区二区在线播放| 日韩在线观看不卡| 日韩av午夜在线观看| 黄色国产精品| 精品国产日韩欧美精品国产欧美日韩一区二区三区 | 欧美激情五月| 99在线精品免费视频九九视| 福利精品在线| 亚洲欧美激情诱惑| 97精品97| 久久国产视频网| 中文欧美日韩| 久久不卡日韩美女| 亚洲最新av| 性欧美69xoxoxoxo| 日韩电影免费网址| 精品免费视频| 国产欧美一区二区色老头|