JavaScript設(shè)計(jì)模式學(xué)習(xí)之適配器模式
概述
適配器模式是設(shè)計(jì)模式行為型模式中的一種模式;
定義:
適配器用來(lái)解決兩個(gè)已有接口之間不匹配的問(wèn)題,它并不需要考慮接口是如何實(shí)現(xiàn),也不用考慮將來(lái)該如何修改;適配器不需要修改已有接口,就可以使他們協(xié)同工作;
白話解釋:
你買(mǎi)了某種電器產(chǎn)品,準(zhǔn)備帶回家好好感受該款產(chǎn)品的魅力;結(jié)果帶回家之后準(zhǔn)備通電使用的時(shí)候,發(fā)現(xiàn)該產(chǎn)品僅支持兩孔插座,而你家里的電源插座都是三孔插座;這個(gè)時(shí)候你總不能又跑去電器專賣店退貨吧;突然靈機(jī)一動(dòng),你想起來(lái)了家里還有多功能電源插座,而多功能電源插座恰好就是三孔,于是你拿出你的多功能電源插座插上電源插座,再拿你電器產(chǎn)品的電源插座插在多功能插座上面的兩孔插座上,開(kāi)始享受美滋滋的生活;這里的多功能插座就是一個(gè)適配器;
代碼實(shí)現(xiàn)
var googleMap = { show: function(){ console.log( '開(kāi)始渲染谷歌地圖' ); } }; var baiduMap = { show: function(){ console.log( '開(kāi)始渲染百度地圖' ); } }; var renderMap = function( map ){ if ( map.show instanceof Function ){ map.show(); } }; renderMap( googleMap ); // 開(kāi)始渲染谷歌地圖 renderMap( baiduMap ); // 開(kāi)始渲染百度地圖
當(dāng)然上面的代碼是能夠正常運(yùn)行的,這得益于這兩個(gè)對(duì)象中的參數(shù)名都是一樣的,所以才能夠正常的運(yùn)行和顯示;
var googleMap = { show: function(){ console.log( '開(kāi)始渲染谷歌地圖' ); } }; var baiduMap = { display: function(){ console.log( '開(kāi)始渲染百度地圖' ); } };
突然有一天如果baiduMap的方法名改變了呢?那么我們?cè)俑厦嬉粯舆\(yùn)行肯定是會(huì)報(bào)錯(cuò)的,因?yàn)閎aiduMap對(duì)象中已經(jīng)沒(méi)有了show()這個(gè)方法了;
使用適配器模式來(lái)修改:
var googleMap = { show: function(){ console.log( '開(kāi)始渲染谷歌地圖' ); } }; var baiduMap = { display: function(){ console.log( '開(kāi)始渲染百度地圖' ); } }; var baiduMapAdapter = { show: function(){ return baiduMap.display(); } }; renderMap( googleMap ); // 開(kāi)始渲染谷歌地圖 renderMap( baiduMapAdapter ); // 開(kāi)始渲染百度地圖
在這段代碼中適配器做的事情其實(shí)很簡(jiǎn)單,就是創(chuàng)建了一個(gè)對(duì)象,添加了一個(gè)同名的show()方法,然后在適配器里面調(diào)用了baiduMap.display()方法,這樣我們只需要在調(diào)用baiduMap的時(shí)候調(diào)用我們的適配器即可達(dá)到預(yù)期效果;
我們作為前端開(kāi)發(fā)人員,對(duì)頁(yè)面上期待得到的數(shù)據(jù)和數(shù)據(jù)格式肯定是比較了解的,但是在前后端分離的開(kāi)發(fā)模式中有的時(shí)候會(huì)遇到這種尷尬的處境:
我們都知道很多UI組件或者工具庫(kù)會(huì)按指定的數(shù)據(jù)格式進(jìn)行渲染,但是這個(gè)時(shí)候后端是不知道的;所以可能接口出來(lái)的數(shù)據(jù)我們是不能直接正常的在頁(yè)面上渲染的,而此時(shí)老板催促我們趕緊上線,而后端堅(jiān)持認(rèn)為數(shù)據(jù)格式?jīng)]問(wèn)題,堅(jiān)決不修改;這個(gè)時(shí)候我們可以通過(guò)適配器模式來(lái)前端格式化數(shù)據(jù);
后端返回的json數(shù)據(jù)格式:
[ { "day": "周一", "uv": 6300 }, { "day": "周二", "uv": 7100 }, { "day": "周三", "uv": 4300 }, { "day": "周四", "uv": 3300 }, { "day": "周五", "uv": 8300 }, { "day": "周六", "uv": 9300 }, { "day": "周日", "uv": 11300 } ]
Echarts圖表圖形需要的數(shù)據(jù)格式:
["周二", "周二", "周三", "周四", "周五", "周六", "周日"] //x軸的數(shù)據(jù) [6300. 7100, 4300, 3300, 8300, 9300, 11300] //坐標(biāo)點(diǎn)的數(shù)據(jù)
雖然心里苦,但還是要解決問(wèn)題!使用適配器來(lái)解決:
//x軸適配器 function echartXAxisAdapter(res) { return res.map(item => item.day); } //坐標(biāo)點(diǎn)適配器 function echartDataAdapter(res) { return res.map(item => item.uv); }
創(chuàng)建兩個(gè)函數(shù)分別對(duì)數(shù)據(jù)按照echarts所需要的數(shù)據(jù)格式進(jìn)行格式化處理即可解決問(wèn)題;這兩個(gè)方法其實(shí)就是一個(gè)適配器,把指定的數(shù)據(jù)丟進(jìn)去即可按照指定規(guī)則輸出我們期待得到的數(shù)據(jù)格式;
總結(jié)
個(gè)人認(rèn)為適配器模式其實(shí)是一種亡羊補(bǔ)牢式的設(shè)計(jì)模式,如果在項(xiàng)目開(kāi)發(fā)的開(kāi)始階段我們就知道我們期待的數(shù)據(jù)格式或者方法名等,我們就可能永遠(yuǎn)都用不到適配器模式;但是項(xiàng)目的迭代往往是不可預(yù)期的,當(dāng)項(xiàng)目迭代之后數(shù)據(jù)格式或者方法名發(fā)生變化之后,我們通常可以使用適配器模式來(lái)進(jìn)行適配解決;當(dāng)然了,最好的解決辦法就是項(xiàng)目開(kāi)發(fā)過(guò)程中前后端協(xié)商討論數(shù)據(jù)格式、文件名等代碼規(guī)范,這樣是對(duì)項(xiàng)目的開(kāi)發(fā)效率是會(huì)有很大的提升的;
以上就是JavaScript設(shè)計(jì)模式學(xué)習(xí)之適配器模式的詳細(xì)內(nèi)容,更多關(guān)于JavaScript設(shè)計(jì)模式的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
- JavaScript適配器模式詳解
- javascript設(shè)計(jì)模式之Adapter模式【適配器模式】實(shí)現(xiàn)方法示例
- JavaScript設(shè)計(jì)模式之適配器模式介紹
- 深入理解JavaScript系列(39):設(shè)計(jì)模式之適配器模式詳解
- 詳解JavaScript實(shí)現(xiàn)設(shè)計(jì)模式中的適配器模式的方法
- javascript設(shè)計(jì)模式 – 適配器模式原理與應(yīng)用實(shí)例分析
- JavaScript 設(shè)計(jì)模式之組合模式解析
- JavaScript組合模式學(xué)習(xí)要點(diǎn)
- 設(shè)計(jì)模式中的組合模式在JavaScript程序構(gòu)建中的使用
- javascript設(shè)計(jì)模式 – 組合模式原理與應(yīng)用實(shí)例分析
- JavaScript設(shè)計(jì)模式開(kāi)發(fā)中組合模式的使用教程
- javascript適配器模式和組合模式原理與實(shí)現(xiàn)方法詳解
相關(guān)文章
調(diào)用jQuery滑出效果時(shí)閃爍的解決方法
這篇文章主要介紹了在調(diào)用jQuery 滑出效果時(shí),層會(huì)現(xiàn)次閃爍一下的解決方法,需要的朋友可以參考下2014-03-03JavaScript??际謱?xiě)題之柯里化與數(shù)組扁平化的實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了JavaScript??际謱?xiě)題中柯里化與數(shù)組扁平化、數(shù)組去重的實(shí)現(xiàn),文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12javascript實(shí)現(xiàn)全角轉(zhuǎn)半角的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)全角轉(zhuǎn)半角的方法,涉及JavaScript字符串遍歷與編碼轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下2016-01-01javascript實(shí)現(xiàn)倒計(jì)時(shí)并彈窗提示特效
倒計(jì)時(shí)的功能在我們做項(xiàng)目的時(shí)候會(huì)經(jīng)常遇到,這里給大家分享的是個(gè)人編寫(xiě)的一個(gè)簡(jiǎn)易的效果代碼,有需要的小伙伴可以參考下2015-06-06JavaScript 處理Iframe自適應(yīng)高度(同或不同域名下)
Iframe自適應(yīng)高度一直都備受關(guān)注,接下來(lái)為大家介紹下同域名下Iframe自適應(yīng)高度的處理以及跨域時(shí)Iframe高度自適應(yīng),感興趣的朋友可以參考下哈2013-03-03利用javascript實(shí)現(xiàn)的三種圖片放大鏡效果實(shí)例(附源碼)
這篇文章主要介紹了利用javascript實(shí)現(xiàn)的幾種放大鏡效果,很實(shí)用一款漂亮的js圖片放大鏡特效,常見(jiàn)于電商網(wǎng)站上產(chǎn)品頁(yè),用來(lái)放大展示圖片細(xì)節(jié),很有實(shí)用性,推薦下載學(xué)習(xí)研究。文中提供了完整的源碼供大家下載,需要的朋友可以參考借鑒,一起來(lái)看看吧。2017-01-01webpack自動(dòng)引入打包資源HtmlWebpackPlugin的實(shí)現(xiàn)
本文主要介紹了webpack自動(dòng)引入打包資源HtmlWebpackPlugin的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07