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

您的位置:首頁技術文章
文章詳情頁

JavaScript適配器模式原理與用法實例詳解

瀏覽:162日期:2023-11-08 10:04:16

本文實例講述了JavaScript適配器模式原理與用法。分享給大家供大家參考,具體如下:

適配模式可用來在現有接口和不兼容的類之間進行適配,使用這種模式的對象又叫包裝器(wrapper),因為它們是在用一個新的接口包裝另一個對象。

基本理論

適配器模式:將一個接口轉換成客戶端需要的接口而不需要去修改客戶端代碼,使得不兼容的代碼可以一起工作。

適配器主要有3個角色組成:

(1)客戶端:調用接口的類(2)適配器:用來連接客戶端接口和提供服務的接口的類(3)適配者:提供服務,但是卻與客戶端接口需求不兼容服務類。

此處 有一個實例是關于兩個數的加法的。

一,先有一個能夠實現,兩個數加法的服務和客戶端。

(1)先引入接口檢驗類----檢查實現該接口的類是否實現了接口中所用方法。

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

(2)使用接口類同一接口

var InterfaceResult=new Interface('InterfaceResult',['add']);

(3)服務端兩個數的加法

function First() { this.add=function (x,y) { return x+y; } Interface.ensureImplement(this,InterfaceResult);//接口檢驗 }

(4)客戶端調用服務端代碼

var first=new First();alert(first.add(1,2)) ;//3

二,現在有一個要求就是,需要換一個類庫,但是客戶端的程序不希望有大的改動。

(1)依然繼承相同接口的基礎上,類庫為

function Second() { this.add=function (numberList) { //[1,2,3] '1+2+3' eval('1+2+3') return eval(numberList.join('+')); } Interface.ensureImplement(this,InterfaceResult);//檢驗當前類是否完全實現接口中的方法 }

此時我們如果需要使用該類庫的話,客戶端又不能該,那么用和之前的調用方式:

var second=new Second();alert(second.add(1,3));//已經不能這樣使用了

是完全不符合客戶端的要求的。為了在保證客戶端不變的情況下,又能使用新的類庫,我們需要使用適配器模式?,F在接口發生了變化,使用適配器兼容,以便適應客戶端的不變

使客戶端與新的接口相會兼容。

(2)適配器

function ThirdWarpper() { this.add=function (x,y) { var arr=new Array(); arr.push(x); arr.push(y); return new Second().add(arr); } Interface.ensureImplement(this,InterfaceResult); }

(3)客戶端代碼

//客戶端 var third=new ThirdWarpper(); var result= third.add(1,8);//傳遞數 alert(result);

針對上述的使用新的類庫后的圖解為:

JavaScript適配器模式原理與用法實例詳解

總結,

從表面上看,適配器模式很像外觀模式。它們都要對別的對象進行包裝并改變其呈現的接口。二者的差別在于它們如何改變接口。外觀元素展現的是一個簡化的接口,它并不提供額外的選擇,而且有時為了方便完成常見任務它還會做出一些假定。而適配器則要把一個接口轉換為另一個接口,它并不會濾除某些能力,也不會簡化接口。

感興趣的朋友可以使用在線HTML/CSS/JavaScript前端代碼調試運行工具:http://tools.jb51.net/code/WebCodeRun測試上述代碼運行效果。

更多關于JavaScript相關內容還可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产精品久久久久久模特| 中文视频一区| 综合一区在线| 国产亚洲一区在线| 美女国产一区| 热久久免费视频| 蜜芽一区二区三区| 蜜桃视频一区二区三区在线观看| 香蕉国产精品| 尤物在线精品| 久久亚洲图片| 久久大逼视频| 国产精品普通话对白| 婷婷丁香综合| 国产视频一区免费看| 国产精品毛片在线| 蜜桃传媒麻豆第一区在线观看| 在线视频观看日韩| 在线国产一区二区| 视频在线观看一区二区三区| 视频一区二区欧美| 亚洲欧美日韩精品一区二区| 蜜臀精品一区二区三区在线观看 | 日本亚洲视频| 中文字幕一区二区三区日韩精品 | 日韩激情av在线| 久久国产人妖系列| 久久影院资源站| 天堂√中文最新版在线| 在线一区视频观看| 玖玖精品视频| 欧美欧美黄在线二区| 精品国产一区二区三区性色av| 97人人精品| 亚洲视频综合| 国产亚洲亚洲| 日韩av午夜在线观看| 久久精品人人| 欧美va天堂在线| 亚洲精品欧洲| 精品视频在线一区二区在线| 欧美日韩一区二区三区视频播放| 亚洲欧美不卡| 国产精品亚洲成在人线| 亚洲人成在线网站| 制服诱惑一区二区| 国产乱论精品| 99视频精品全国免费| 偷拍精品精品一区二区三区| 九色精品91| 日韩精品国产精品| 日韩大片在线| 欧美中文字幕| 久久精品国产一区二区| 亚洲激情不卡| 欧美激情三区| 亚洲精品国产偷自在线观看| 国产日产精品_国产精品毛片| 桃色av一区二区| 亚洲日本三级| 欧美激情另类| 中文字幕一区二区三区日韩精品| 精品国产麻豆| 蜜桃传媒麻豆第一区在线观看| 国产伦理久久久久久妇女| 久久九九精品| 日韩av一级片| 国内激情久久| 日本中文字幕视频一区| 国产v综合v| 日韩av网站免费在线| 成人羞羞视频在线看网址| 亚洲精选成人| 久久人人97超碰国产公开结果| 中文字幕日本一区| 国产综合色区在线观看| 日本亚洲欧美天堂免费| 丝袜美腿诱惑一区二区三区| 欧美日韩1区| 日韩欧美一区二区三区免费看| 四虎国产精品免费久久| 色爱综合av| 卡一卡二国产精品| 亚洲综合不卡| 亚洲精品在线影院| 国产精品观看| 亚洲特色特黄| 日韩大片在线| 国产精品久久久免费| 免费看黄色91| 色天使综合视频| 国产欧美日韩在线观看视频| 欧美日韩国产亚洲一区| 伊人网在线播放| 国产精品中文字幕制服诱惑| 9国产精品视频| 亚洲午夜天堂| 国产精久久久| 国产探花在线精品一区二区| 欧美专区18| 黄页网站一区| 欧美羞羞视频| 成人在线视频免费看| 青青伊人久久| 蜜桃一区二区三区在线| 亚洲精品国产偷自在线观看| 毛片在线网站| 国产一区二区三区不卡av| 欧美一级一区| 中文不卡在线| 日韩视频不卡| 亚洲一区二区三区高清| 久久久久蜜桃| 日韩中文在线电影| 裤袜国产欧美精品一区| 精品一区二区三区亚洲| 久久超碰99| 久久国产免费看| 欧美日一区二区三区在线观看国产免 | 清纯唯美亚洲综合一区| 久久性天堂网| 免费看日韩精品| 丝袜美腿高跟呻吟高潮一区| 亚洲精品一二三区区别| 亚洲午夜久久久久久尤物| 在线中文字幕播放| xxxxx性欧美特大| 午夜影院一区| 日韩影院二区| 久久婷婷久久| 99久久亚洲精品| 激情久久久久久| 亚洲大全视频| 亚洲欧美日韩国产综合精品二区| 激情久久中文字幕| 伊人久久成人| 蘑菇福利视频一区播放| 蜜桃久久av一区| 日韩精品免费视频一区二区三区| 一区二区精彩视频| 婷婷综合福利| 啪啪亚洲精品| 久久av偷拍| 给我免费播放日韩视频| 日韩国产在线| 国产高清一区二区| 水蜜桃久久夜色精品一区的特点| 麻豆精品网站| 欧美天堂一区| 国产乱人伦精品一区| 精品久久视频| 日韩中文字幕高清在线观看| 999国产精品| 影音先锋国产精品| 中文字幕av一区二区三区人| 欧美日韩 国产精品| 精品久久美女| 免费国产自久久久久三四区久久| 蘑菇福利视频一区播放| 日韩不卡在线观看日韩不卡视频 | 亚洲影院天堂中文av色| 国产精品一区二区三区av| 国产日产精品_国产精品毛片 | 久久av免费看| 日韩欧美一区免费| 香蕉视频成人在线观看| 亚洲精品系列| 日韩av中文字幕一区| 国产精品videossex久久发布| 中文在线а√在线8| 亚洲精品99| 欧美亚洲福利| 日韩精品永久网址| 在线亚洲欧美| 国产精品乱战久久久| 天堂中文在线播放| 亚洲欧洲免费| 久久久国产精品网站| 亚洲二区三区不卡| 国产日韩欧美中文在线| 欧美精品日日操| 免费美女久久99| 卡一卡二国产精品| 欧美日韩一二三四| 欧美日韩国产一区二区在线观看| 黄色网一区二区| 手机精品视频在线观看| 精品国产欧美| 视频一区欧美精品| 久久久久久久欧美精品| 亚洲+小说+欧美+激情+另类| 国产一区 二区| 日韩精品免费一区二区三区| 亚洲日本久久| 一本大道色婷婷在线| 午夜亚洲福利| www.九色在线| 日韩高清电影免费| 精品成人18| 亚洲深深色噜噜狠狠爱网站|