位置: 编程技术 - 正文

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

编辑:rootadmin

推荐整理分享详解JavaScript实现设计模式中的适配器模式的方法(javascriptz),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascriptz,javascript+,javascriptjs,javascript+,js的实现原理,javascript详细介绍,js实例教程,javascript详细介绍,内容如对您有帮助,希望把文章链接给更多的朋友!

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

基本理论

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

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

适配器模式的实现

1.最简单的适配器

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

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

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

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

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

2.实际应用

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

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

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

总结

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

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

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

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

Adapter适配器模式在JavaScript设计模式编程中的运用分析 定义适配器模式(Adapter)是将一个类(对象)的接口(方法或属性)转化成客户希望的另外一个接口(方法或属性),适配器模式使得原本由于接口不

实现JavaScript的组成----BOM和DOM详解 我们知道,一个完整的JavaScript的实现,需要由三部分组成:ECMAScript(核心),BOM(浏览器对象模型),DOM(文档对象模型)。今天主要学习BOM和DOM。BOM:BOM提供了

JavaScript 基础函数_深入剖析变量和作用域 函数定义和调用定义函数,在JavaScript中,定义函数的方式如下:functionabs(x){if(x=0){returnx;}else{return-x;}}上述abs()函数的定义如下:function指出这是一个函数

标签: javascriptz

本文链接地址:https://www.jiuchutong.com/biancheng/370048.html 转载请保留说明!

上一篇:设计模式中的facade外观模式在JavaScript开发中的运用(设计模式中的行为模式)

下一篇:Adapter适配器模式在JavaScript设计模式编程中的运用分析(适配器模型)

  • 小规模缴纳企业所得税会计分录
  • 劳务税是什么 和个税的区别
  • 息税前利润变动率的计算公式
  • 商务费用报销一般有哪些流程
  • 外贸企业进项税额
  • 全年没有超过起征点需要汇算吗
  • 研发费用可以计入哪个科目
  • 自然人个税申报换电脑数据怎么合并
  • 赠送货物怎么入账
  • 绿化工程账务处理支出
  • 亏损企业能不能无常捐赠
  • 外购原材料自用
  • 增值税如何减税
  • 银行卡收到养老金是什么意思
  • 小企业采用什么折旧方法
  • 年终奖个税公式表最新
  • 什么情况下可以收取现金
  • 生活服务的发票可以报销吗
  • 销售房地产要交培训费是传销行为吗
  • 企业支付宝可以转账到对公账户吗
  • 个人独资企业出资额是注册资本吗
  • 产业政策鼓励类
  • win10夜间模式怎么打开不了
  • 其他应付款无法支付的账务处理方法
  • 发票丢失如何处理
  • 建安混合销售能分开吗
  • 金银首饰在哪个软件买
  • 微软商店 低价区
  • php中使用什么关键字定义常量
  • php循环语句
  • 广告公司的设计服务费计入什么科目
  • 工业企业制造费用核算范围
  • 收不回的应收账款分录
  • php imagettftext
  • windows安装无法继续,若要安装请重新启动
  • 前端控制台
  • 印花税具体包括哪几类
  • git简明教程
  • PHP HTTP 认证实例详解
  • python如何删除字典中的键值对
  • 地方水利建设基金的会计分录
  • 微信公众号认证主体是什么意思
  • 其他应收款抵货款怎么记账
  • 先做凭证再付款
  • 制造费用月末一般有余额吗
  • java自增自减运算符的规则
  • pycharm cant find main
  • 案例详解:功能点估算法
  • sqlserver还原数据库一直显示正在执行0%
  • 企业重组的特殊性税务处理例题
  • 计算业务招待费扣除限额的基础包括营业外收入
  • 一般纳税人租赁费税率5%是简易征收吗?
  • 应收账款科目如何核算
  • 住宿费用专票可以抵扣吗
  • 贴现利息高好还是低好
  • 无形资产摊销如何记账
  • 分享sql日期时间格式
  • sqlserver数据库事物日志已满
  • mysql数据库迁移到达梦
  • 当恢复系数e=1时碰撞属于什么碰撞
  • xp如何把ie浏览器设置为默认浏览器
  • linux中的ls命令的功能是变换工作目录到目标指定目录
  • win8系统计算机在哪里
  • win7系统如何删除隐藏文件
  • macbook恢复macos
  • SIMETER.EXE - SIMETER是什么进程 有什么用
  • win7休眠模式在哪
  • WIN7快捷键冲突怎么解决
  • cocos2dx 2.2.2
  • android 音频焦点丢失 媒体按键
  • 安卓手机更新时间
  • javascript零基础入门书籍
  • java learning
  • python程序开发
  • email js
  • 如何理解js的面向对象
  • 河南省地方税务局公告2017年第4号
  • 国家税务总局遴选拟录取名单
  • 贵州铜仁苗族自治区
  • 税率分几种 分别是什么
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设