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

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

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

瀏覽:164日期: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));//已經不能這樣使用了

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

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

(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久久,三上悠亚国产精品一区二区三区
日韩在线看片| 97精品国产一区二区三区| 免费污视频在线一区| 国产一区二区三区不卡av| 麻豆久久久久久久| 美女性感视频久久| 国产精品qvod| 久久伊人久久| 久久精品99国产国产精| 日韩va亚洲va欧美va久久| 五月激激激综合网色播| 日韩在线观看中文字幕| 91精品一区二区三区综合| 免费国产自久久久久三四区久久 | 欧美精品一区二区三区精品| 久久在线电影| 亚洲专区欧美专区| 亚洲专区视频| 国产美女精品视频免费播放软件| 亚洲欧洲免费| 日韩av一区二区三区| 国产精品成人**免费视频| 成人在线免费观看网站| 久久精品观看| 美女久久网站| 欧美精品影院| 黑人精品一区| 最新亚洲一区| 日韩va亚洲va欧美va久久| 久久av日韩| 日本欧美不卡| 亚洲一区二区三区四区电影| 国产欧美高清| 色一区二区三区四区| 日韩欧美自拍| 午夜一级久久| 国产精品天堂蜜av在线播放| 日韩不卡一区| 国产一区久久| 18国产精品| av资源亚洲| 日韩专区欧美专区| 久久99性xxx老妇胖精品| 在线观看精品| 日韩欧美久久| 国产精品久久久久久久久妇女| 欧美日韩国产高清| 国产精品中文字幕制服诱惑| 日韩大片免费观看| 亚洲综合日本| 精品美女视频 | 五月婷婷亚洲| 青青草91久久久久久久久| 久久久久久网| 在线精品国产亚洲| 福利精品在线| 一区二区三区网站| 国际精品欧美精品| 亚洲一级在线| 国产精品宾馆| 野花国产精品入口| 精品国产一区二区三区2021| 老司机精品久久| av中文字幕在线观看第一页| 亚洲精品韩国| 91精品国产调教在线观看| 欧美一区免费| 欧美日韩免费观看一区=区三区| 久久国产日韩欧美精品| 91精品国产91久久久久久黑人| 国产亚洲一区二区三区啪| 亚洲婷婷在线| 精品国产18久久久久久二百| 伊人www22综合色| 国产在线观看www| 日韩欧美精品一区二区综合视频| 久久国产电影| 精品欠久久久中文字幕加勒比| 亚洲婷婷丁香| 亚洲91久久| 国产精品福利在线观看播放| 日韩国产在线一| 亚洲深爱激情| 久久精品主播| 欧美韩日一区| 国产精品99精品一区二区三区∴| 亚洲免费影视| 久久精品在线| 国产精品成人a在线观看| 日本伊人午夜精品| 中文日韩在线| 美女毛片一区二区三区四区| 中文在线免费视频| 精品视频高潮| 久久99影视| 国产精品美女午夜爽爽| 婷婷亚洲精品| 日韩亚洲国产欧美| 国产精品99免费看| 视频福利一区| 肉色欧美久久久久久久免费看| 久久av导航| 国产精品porn| 国产精品二区影院| 久久国产三级| 日韩有吗在线观看| 蜜桃久久久久久久| 亚洲免费网址| 99国产精品| 午夜欧美理论片| 欧美va天堂在线| 久久久夜夜夜| 91精品蜜臀一区二区三区在线| 桃色一区二区| 久久久水蜜桃av免费网站| 成人日韩在线观看| 日本综合字幕| 四虎4545www国产精品 | 91亚洲成人| 日韩av专区| 欧美久久天堂| 天堂а√在线最新版中文在线| 狠狠久久伊人中文字幕| 国产一区二区三区91| 国产videos久久| 精品国产精品久久一区免费式| 精品国产乱码久久久久久1区2匹| 国内精品麻豆美女在线播放视频| 国产日韩一区二区三区在线| 国产欧美啪啪| 蜜桃久久久久| 黑森林国产精品av| 国产精品久久久久av电视剧| 久久在线电影| 久久国产精品亚洲77777| 免费黄网站欧美| 综合五月婷婷| 欧美日韩 国产精品| 国产精品一区亚洲| 国产一区二区三区四区| 日韩欧美中文| 自拍日韩欧美| 亚洲人成亚洲精品| 日韩精品高清不卡| 老牛国内精品亚洲成av人片| 成人三级高清视频在线看| 日韩中文字幕高清在线观看| 香蕉精品视频在线观看| 久久亚洲精品伦理| 热久久久久久| 精品久久国产一区| 激情综合亚洲| 亚洲精品美女91| 国产精品草草| 久久久久久黄| 综合视频一区| 精品伊人久久久| 久久国产亚洲精品| 女同性一区二区三区人了人一| 日韩制服丝袜先锋影音| 欧美色综合网| 日本不卡免费高清视频在线| 亚洲欧美日本日韩| 91av一区| 亚洲www啪成人一区二区| 国产视频一区欧美| **爰片久久毛片| 蜜桃av在线播放| 久久成人精品| 久久爱www成人| 国产综合婷婷| 日本欧美一区二区| 成人国产综合| 婷婷综合亚洲| 国产精品一区毛片| 一区二区小说| 欧美在线看片| 亚洲国产专区| 欧美日韩在线精品一区二区三区激情综合| 国产91欧美| 久久福利影视| 精品视频一区二区三区在线观看 | 久久精品99久久无色码中文字幕| 日本在线观看不卡视频| 日韩精品不卡一区二区| 在线一区二区三区视频| 国产精品毛片久久久| 欧美~级网站不卡| 国产欧美另类| 日韩网站在线| 成人国产精选| 日韩国产欧美视频| 久久久久蜜桃| 国产精品亚洲一区二区在线观看| 久久久久久黄| 国产精品www.| 亚洲视频电影在线| 久久久精品午夜少妇| 国产精品主播在线观看| 亚洲综合另类|