0

0

前端的设计模式系列-适配器模式

雪夜

雪夜

发布时间:2025-07-21 10:38:35

|

713人浏览过

|

来源于php中文网

原创

在学习和总结设计模式的过程中,确实有必要根据具体的编程语言来调整和理解这些模式。在javascript中,由于其基于原型的动态特性,设计模式的实现可能与传统的静态类型语言有所不同。以下是关于适配器模式的详细总结,按照您提出的“场景” - “设计模式定义” - “代码实现” - “更多场景” - “总”的顺序进行:

场景

在使用第三方库时,常常会遇到当前接口与第三方接口不匹配的情况。例如,使用一个Table组件,它要求返回的表格数据格式如下:

{
  code: 0, // 业务 code
  msg: '', // 出错时候的提示
  data: {
    total: , // 总数量
    list: [], // 表格列表
  }
};

但后端返回的数据格式可能是这样的:

{
  code: 0, // 业务 code
  message: '', // 出错时候的提示
  data: {
    total: , // 总数量
    records: [], // 表格列表
  }
};

此时,可以通过适配器模式进行数据格式的转换。

设计模式定义

维基百科对适配器模式的定义是:在不改变现有类的基础上,让它们能够正常使用另一个类。适配器模式在基于类的语言中有两种实现方式:

立即学习前端免费学习笔记(深入)”;

  1. 组合方式:适配器类内部包含原对象的实例。
  2. 继承方式:适配器类直接继承原类。

以下是UML类图的示例:

前端的设计模式系列-适配器模式

左边的Adapter内部拥有Adaptee的实例,右边的Adapter类直接继承Adaptee类。适配器会将AdapteespecificOperation方法进行相应的处理,包装为operation方法供client使用。

代码实现

在JavaScript中,我们可以使用函数来实现适配器模式。让我们用一个简单的例子来说明:现实生活中,iPhone有两种耳机插口,一种是Lightning,一种是传统的3.5毫米接口。如果是Lightning插口的耳机想要插到传统的3.5毫米接口的电脑上,就需要适配器。

HTShop网上购物系统
HTShop网上购物系统

HTShop网上购物系统由恒天网络科技有限公司根据国际先进技术和国内商务特点自主版权开发的一款具有强大功能的B2C电子商务网上购物平台。HTShop以国际上通用流行的B/S(浏览器/服务器)模式进行设计,采用微软公司的ASP.NET(C#)技术构建而成。 2007-11-10 HTShop CS 通用标准版 v1.1.11.10 更新内容自由更换模版功能开放 修改了购买多款商品,会员中心订单只显示

下载

首先,我们用Java来展示传统的适配器模式实现:

class Lightning耳机 {
    public void 插入Lighting接口() {
        System.out.println("插入到Lighting耳机接口成功");
    }
}
<p>class 传统耳机 {
public void 插入到传统耳机孔() {
System.out.println("插入到传统耳机孔成功");
}
}</p><p>class Lightning耳机到传统耳机适配器 extends 传统耳机 {
public Lightning耳机 Lightning耳机;</p><pre class="brush:php;toolbar:false;"><code>public Lightning耳机到传统耳机适配器(Lightning耳机 耳机) {
    Lightning耳机 = 耳机;
}

public void 插入到传统耳机孔() {
    Lightning耳机.插入Lighting接口();
}

}

class 电脑传统耳机孔 { public 传统耳机 耳机;

<code>public 电脑传统耳机孔(传统耳机 传统耳机) {
    耳机 = 传统耳机;
}

public void 插入耳机() {
    耳机.插入到传统耳机孔();
}</code>

}

public class Main { public static void main(String[] args) { 传统耳机 传统耳机 = new 传统耳机(); 电脑传统耳机孔 电脑传统耳机孔 = new 电脑传统耳机孔(传统耳机); 电脑传统耳机孔.插入耳机(); // 插入到传统耳机孔成功

<code>    Lightning耳机 Lightning耳机 = new Lightning耳机();
    电脑传统耳机孔 电脑传统耳机孔2 = new 电脑传统耳机孔(new Lightning耳机到传统耳机适配器(Lightning耳机));
    电脑传统耳机孔2.插入耳机(); // 插入到Lighting耳机接口成功
}</code>

}

接下来,我们将其转换为JavaScript的实现:

const Lightning耳机 = {
插入Lighting接口() {
console.log("插入到Lighting耳机接口成功");
}
};</p><p>const 传统耳机 = {
插入到传统耳机孔() {
console.log("插入到传统耳机孔成功");
}
};</p><p>const 电脑传统耳机孔 = {
插入耳机(耳机) {
耳机.插入到传统耳机孔();
}
};</p><p>const Lightning耳机到传统耳机适配器 = function(Lightning耳机) {
return {
插入到传统耳机孔() {
Lightning耳机.插入Lighting接口();
}
};
};</p><p>电脑传统耳机孔.插入耳机(传统耳机); // 插入到传统耳机孔成功
电脑传统耳机孔.插入耳机(Lightning耳机到传统耳机适配器(Lightning耳机)); // 插入到Lighting耳机接口成功

回到开头的问题,Table组件提供了一个responseProcessor的钩子,我们可以通过这个钩子将接口返回的数据进行包装:

{
...
responseProcessor(res) {
return {
...res,
msg: res.message, // 出错时候的提示
data: {
...res.data,
list: res?.data?.records || [], // 表格列表
}
};
},
...
}

更多场景

除了应对数据格式不一致的问题,适配器模式还可以为上层提供统一接口,解决兼容性问题。一个典型的例子是jQuery,它通过适配器模式来处理不同浏览器的兼容性问题。例如:

// Create the request object
// (This is still attached to ajaxSettings for backward compatibility)
jQuery.ajaxSettings.xhr = window.ActiveXObject !== undefined ?
// Support: IE6-IE8
function() {
// XHR cannot access local files, always use ActiveX for that case
if (this.isLocal) {
return createActiveXHR();
}
// Support: IE 9-11
// IE seems to error on cross-domain PATCH requests when ActiveX XHR
// is used. In IE 9+ always use the native XHR.
// Note: this condition won't catch Edge as it doesn't define
// document.documentMode but it also doesn't support ActiveX so it won't
// reach this code.
if (document.documentMode > 8) {
return createStandardXHR();
}
// Support: IE
} :
createStandardXHR;

适配器模式是一种相对简单的设计模式,在JavaScript中可以通过函数进行转换。适配器模式和代理模式在代码结构上相似,但它们的意图不同:适配器模式是为了解决两个对象之间不匹配的问题,而代理模式是为了增强原对象的功能,提供的接口不会改变。

通过学习和总结适配器模式,我们可以更好地理解如何在JavaScript中应用设计模式,以解决实际开发中的问题。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

334

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

406

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

515

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

312

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

128

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

183

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

51

2026.01.13

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

3

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 10.5万人学习

Git 教程
Git 教程

共21课时 | 4.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号