详解JavaScript实现设计模式中的适配器模式的方法


Posted in Javascript onMay 18, 2016

有的时候在开发过程中,我们会发现,客户端需要的接口和提供的接口发生不兼容的问题。由于特殊的原因我们无法修改客户端接口。在这种情况下,我们需要适配现有接口和不兼容的类,这就要提到适配器模式。通过适配器,我们可以在不用修改旧代码的情况下也能使用它们,这就是适配器的能力。
适配模式可用来在现有接口和不兼容的类之间进行适配,使用这种模式的对象又叫包装器(wrapper),因为它们是在用一个新的接口包装另一个对象。
从表面上看,适配器模式很像外观模式。它们都要对别的对象进行包装并改变其呈现的接口。二者的差别在于它们如何改变接口。外观元素展现的是一个简化的接口,它并不提供额外的选择,而且有时为了方便完成常见任务它还会做出一些假定。而适配器则要把一个接口转换为另一个接口,它并不会滤除某些能力,也不会简化接口。如果客户系统API不可用,就需要用到适配器。

基本理论

适配器模式:将一个接口转换成客户端需要的接口而不需要去修改客户端代码,使得不兼容的代码可以一起工作。

适配器主要有3个角色组成:
(1)客户端:调用接口的类
(2)适配器:用来连接客户端接口和提供服务的接口的类
(3)适配者:提供服务,但是却与客户端接口需求不兼容服务类。

适配器模式的实现

1.最简单的适配器

适配器模式没有想象中的那么复杂,举个最简单的例子。
客户端调用一个方法进行加法计算:

var result = add(1,2);

但是我们没有提供add这个方法,提供了同样类似功能的sum方法:

function sum(v1,v2){
  return v1 + v2;
}

为了避免修改客户端和服务端,我们增加一个包装函数:

function add (v1,v2){
  reutrn sum(v1,v2);
}

这就是一个最简单的适配器模式,我们在两个不兼容的接口之间添加一个包装方法,用这个方法来连接二者使其共同工作。

2.实际应用

随着前端框架的发展,越来越多的开发者开始使用MVVM框架进行开发,只需要操作数据而不需要操作DOM元素,jQuery的作用越来越少。而很多项目中还是引用着jQuery库作用工具类,因为我们要利用jQuery提供的ajax去服务器请求数据。如果jQuery在项目中的作用仅仅是作为ajax工具库的话,有点杀鸡焉用牛刀的感觉,造成资源浪费。这个时候我们完全可以封装一个自己的ajax库。
假设我们封装的ajax就通过一个函数进行使用:

ajax({
  url:'/getData',
  type:'Post',
  dataType:'json',
  data:{
    id:"123"
  }
})
.done(function(){})

除了调用接口ajax与jQuery的$.ajax的不同,其他完全一样。
项目中请求ajax的地方必然很多,我们替换jQuery的时候不可能一个一个去修改$.ajax,那怎么办呢,这个时候,我们就可以增加一个适配器:

var $ = {
  ajax:function (options){
    return ajax(options);
  }
}

这样就能兼容旧代码和新接口,避免对已有的代码的修改。

总结

适配器模式的原理很简单,就是新增一个包装类,对新的接口进行包装以适应旧代码的调用,避免修改接口和调用代码。
适用场景:存在较多代码调用旧接口,为了避免修改旧代码和更换新接口,不影响现有实现方式的应用场景。

1.适配器模式的适用场合:
适配器适用于客户系统期待的接口与现有API提供的接口不兼容这种场合。适配器所适配的两个方法执行的应该是类似的任务,否则的话就解决不了问题。就像桥接元素和外观元素一样,通过创建适配器,可以把抽象与其实现隔离开来,以便二者独立变化。

2.适配器模式之利:
用一个新的接口对现有类的接口进行包装,这样客户程序就能使用这个并非为其量身打造的类而又无需为此大动手术。

3.设配器模式之弊:
有人认为适配器是一种不必要的开销,完全可以通过重写现有代码避免。此外适配器模式也会引入一批需要支持的新工具。如果现有API还未定形,或者新接口还未定形,那么适配器可能不会一直管用。
在涉及大型系统和遗留框架的情况下,它的优点往往比缺点更突出。

Javascript 相关文章推荐
js下用eval生成JSON对象
Sep 17 Javascript
javascript中callee与caller的用法和应用场景
Dec 08 Javascript
IE6 hack for js 集锦
Sep 23 Javascript
jQuery+CSS3实现树叶飘落特效
Feb 01 Javascript
一个用jquery写的判断div滚动条到底部的方法【推荐】
Apr 29 Javascript
jquery点击切换背景色的简单实例
Aug 25 Javascript
JS添加或修改控件的样式(Class)实现方法
Oct 15 Javascript
[原创]JS基于FileSaver.js插件实现文件保存功能示例
Dec 08 Javascript
js 单引号替换成双引号,双引号替换成单引号的实现方法
Feb 16 Javascript
jQuery实现的页面弹幕效果【测试可用】
Aug 17 jQuery
JavaScript事件发布/订阅模式原理与用法分析
Aug 21 Javascript
JS代码实现页面切换效果
Jan 10 Javascript
深入剖析javascript中的exec与match方法
May 18 #Javascript
JQuery中attr属性和jQuery.data()学习笔记【必看】
May 18 #Javascript
设计模式中的facade外观模式在JavaScript开发中的运用
May 18 #Javascript
JQuery.validate在ie8下不支持的快速解决方法
May 18 #Javascript
12个非常实用的JavaScript小技巧【推荐】
May 18 #Javascript
JQuery解析XML数据的几个简单实例
May 18 #Javascript
JavaScript设计模式开发中组合模式的使用教程
May 18 #Javascript
You might like
PHP 函数call_user_func和call_user_func_array用法详解
2014/03/02 PHP
PHP里的单例类写法实例
2015/06/25 PHP
详解WordPress开发中wp_title()函数的用法
2016/01/07 PHP
SSO单点登录的PHP实现方法(Laravel框架)
2016/03/23 PHP
php输出图像的方法实例分析
2017/02/16 PHP
详解laravel passport OAuth2.0的4种模式
2019/11/04 PHP
用js实现控制内容的向上向下滚动效果
2007/06/26 Javascript
不能再简单的无闪刷新验证码原理很简单
2007/11/05 Javascript
jQuery formValidator表单验证插件开源了 含API帮助、源码、示例
2008/08/14 Javascript
JQuery 选择器、过滤器介绍
2011/02/14 Javascript
浅析jQuery(function(){})与(function(){})(jQuery)之间的区别
2014/01/09 Javascript
js实现上一页下一页的效果【附代码】
2016/03/10 Javascript
JS中mouseover和mouseout多次触发问题如何解决
2016/06/06 Javascript
一个超简单的jQuery回调函数例子(分享)
2016/08/08 Javascript
ng2学习笔记之bootstrap中的component使用教程
2017/03/09 Javascript
关于微信小程序bug记录与解决方法
2018/08/15 Javascript
微信小程序错误this.setData报错及解决过程
2019/09/18 Javascript
Vue实现背景更换颜色操作
2020/07/17 Javascript
JavaScript常用工具函数汇总(浏览器环境)
2020/09/17 Javascript
[49:07]VGJ.T vs Optic Supermajor小组赛D组 BO3 第二场 6.3
2018/06/04 DOTA
python网络编程学习笔记(三):socket网络服务器
2014/06/09 Python
python如何获取服务器硬件信息
2017/05/11 Python
python机器学习之决策树分类详解
2017/12/20 Python
在Python中,不用while和for循环遍历列表的实例
2019/02/20 Python
Tensorflow中的dropout的使用方法
2020/03/13 Python
matplotlib quiver箭图绘制案例
2020/04/17 Python
python 使用cycle构造无限循环迭代器
2020/12/02 Python
苏宁红孩子母婴商城:redbaby
2017/02/12 全球购物
英国第一豪华护肤品牌:Elemis
2017/10/12 全球购物
美国工业用品采购网站:Zoro.com
2020/10/27 全球购物
党校学习思想汇报
2014/01/06 职场文书
实习单位指导教师评语
2014/12/30 职场文书
证劵公司反洗钱宣传活动总结
2015/05/08 职场文书
调解协议书范本
2016/03/21 职场文书
mysql insert 存在即不插入语法说明
2022/03/25 MySQL
python实现手机推送 代码也就10行左右
2022/04/12 Python