午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

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

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

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

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

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

基本理論

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

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

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

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

一,先有一個能夠實現(xiàn),兩個數(shù)加法的服務和客戶端。

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

//(定義一個靜態(tài)方法來實現(xiàn)接口與實現(xiàn)類的直接檢驗//靜態(tài)方法不要寫出Interface.prototype ,因為這是寫到接口的原型鏈上的//我們要把靜態(tài)的函數(shù)直接寫到類層次上//定義一個接口類var Interface=function (name,methods) {//name:接口名字 if(arguments.length<2){ alert('必須是兩個參數(shù)') } this.name=name; this.methods=[];//定義一個空數(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個') return false; } for(var i=1;i<arguments.length;i++){ var inter=arguments[i]; //如果是接口就必須是Interface類型 if(inter.constructor!=Interface){ throw new Error('如果是接口類的話,就必須是Interface類型'); } //判斷接口中的方法是否全部實現(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' ){//實現(xiàn)類中必須有方法名字與接口中所用方法名相同throw new Error('實現(xiàn)類中沒有完全實現(xiàn)接口中的所有方法') } } }}

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

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

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

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

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

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

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

(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);//檢驗當前類是否完全實現(xiàn)接口中的方法 }

此時我們?nèi)绻枰褂迷擃悗斓脑挘蛻舳擞植荒茉摚敲从煤椭暗恼{(diào)用方式:

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

是完全不符合客戶端的要求的。為了在保證客戶端不變的情況下,又能使用新的類庫,我們需要使用適配器模式。現(xiàn)在接口發(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);//傳遞數(shù) alert(result);

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

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

總結,

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

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

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

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 狠狠淫| 欧美大片免费看 | 台湾久久| 亚洲一区二区三区视频 | 国产成人亚洲精品自产在线 | 成人黄色免费观看 | 欧美少妇bbw| 依依成人综合网 | 五月婷婷综合在线 | 国产激情无套内精对白视频 | 国产视频久久久久久 | 国产精品久久久久久久久久久久久久久久 | 青青草色视频 | 天天综合色网 | 亚洲高清在线观看视频 | 一级黄色免费网站 | 亚洲麻豆 | 成人福利视频在线观看 | 亚洲精品三级 | 日本黄色高清 | 黄色三级视屏 | 午夜成人影片 | 黄色小视频在线免费看 | 自拍欧美亚洲 | 久在线 | 全部孕妇毛片丰满孕妇孕交 | 肉色超薄丝袜脚交69xx图片 | 91极品在线| 日本在线国产 | 视频在线观看一区二区 | 国产一区在线免费 | 99热99精品 | 日韩欧美一区二区三区四区 | 久久国产精品一区二区三区 | 久久精品在线观看视频 | 亚洲天堂视频网站 | 国产18页| 久久免费在线视频 | 成人自拍视频在线观看 | 欧美性猛交xxxx乱 | 岛国av大片 |