0

0

可扩展 Web 开发的基本 JavaScript 设计模式

碧海醫心

碧海醫心

发布时间:2024-12-08 10:33:01

|

350人浏览过

|

来源于dev.to

转载

可扩展 web 开发的基本 javascript 设计模式

javascript 设计模式是构建可扩展且可维护的应用程序的重要工具。作为一名开发人员,我发现实现这些模式可以显着改善代码组织并降低复杂性。让我们探索在我的项目中已被证明非常有价值的五种关键设计模式。

当您需要确保某个类在整个应用程序中只有一个实例时,单例模式是一种强大的方法。此模式对于管理全局状态或协调整个系统的操作特别有用。这是我如何在 javascript 中实现单例模式的示例:

const singleton = (function() {
  let instance;

  function createinstance() {
    const object = new object("i am the instance");
    return object;
  }

  return {
    getinstance: function() {
      if (!instance) {
        instance = createinstance();
      }
      return instance;
    }
  };
})();

const instance1 = singleton.getinstance();
const instance2 = singleton.getinstance();

console.log(instance1 === instance2); // true

在此示例中,单例是使用立即调用函数表达式 (iife) 实现的。 getinstance 方法确保只创建并返回一个实例,无论调用多少次。

观察者模式是我在项目中经常使用的另一个重要设计模式。它建立了一个订阅模型,其中对象(观察者)会自动通知另一个对象(主题)的任何状态变化。该模式是事件驱动编程的基础,广泛应用于用户界面工具包中。这是一个基本的实现:

class subject {
  constructor() {
    this.observers = [];
  }

  subscribe(observer) {
    this.observers.push(observer);
  }

  unsubscribe(observer) {
    this.observers = this.observers.filter(obs => obs !== observer);
  }

  notify(data) {
    this.observers.foreach(observer => observer.update(data));
  }
}

class observer {
  update(data) {
    console.log('observer received data:', data);
  }
}

const subject = new subject();
const observer1 = new observer();
const observer2 = new observer();

subject.subscribe(observer1);
subject.subscribe(observer2);

subject.notify('hello, observers!');

此模式在构建复杂的用户界面或处理异步操作时特别有用。

工厂模式是一种创建模式,当我需要创建对象而不指定其确切类时,我经常使用它。此模式提供了一种将实例化逻辑委托给子类的方法。这是我如何使用工厂模式的示例:

class car {
  constructor(options) {
    this.doors = options.doors || 4;
    this.state = options.state || 'brand new';
    this.color = options.color || 'white';
  }
}

class truck {
  constructor(options) {
    this.wheels = options.wheels || 6;
    this.state = options.state || 'used';
    this.color = options.color || 'blue';
  }
}

class vehiclefactory {
  createvehicle(options) {
    if (options.vehicletype === 'car') {
      return new car(options);
    } else if (options.vehicletype === 'truck') {
      return new truck(options);
    }
  }
}

const factory = new vehiclefactory();
const car = factory.createvehicle({
  vehicletype: 'car',
  doors: 2,
  color: 'red',
  state: 'used'
});

console.log(car);

当处理复杂对象或直到运行时才知道所需对象的确切类型时,此模式特别有用。

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

模块模式是我最喜欢的封装代码和数据的模式之一。它提供了一种创建私有和公共访问级别的方法,并有助于将代码组织成干净、独立的部分。以下是我通常如何实现模块模式:

const mymodule = (function() {
  // private variables and functions
  let privatevariable = 'i am private';
  function privatefunction() {
    console.log('this is a private function');
  }

  // public api
  return {
    publicvariable: 'i am public',
    publicfunction: function() {
      console.log('this is a public function');
      privatefunction();
    }
  };
})();

console.log(mymodule.publicvariable);
mymodule.publicfunction();
console.log(mymodule.privatevariable); // undefined

此模式非常适合创建具有清晰接口的独立代码模块。

原型模式是当我需要通过克隆基于现有对象的模板创建对象时使用的模式。当对象创建成本昂贵并且需要类似的对象时,此模式特别有用。这是一个例子:

const vehiclePrototype = {
  init: function(model) {
    this.model = model;
  },
  getModel: function() {
    console.log('The model of this vehicle is ' + this.model);
  }
};

function vehicle(model) {
  function F() {}
  F.prototype = vehiclePrototype;

  const f = new F();
  f.init(model);
  return f;
}

const car = vehicle('Honda');
car.getModel();

此模式允许创建具有特定原型的新对象,这比从头开始创建新对象更有效。

在我的项目中实现这些模式时,我发现它们显着提高了代码组织和可维护性。例如,单例模式对于管理大型应用程序中的全局状态非常有价值。我用它来创建需要在整个应用程序中访问的配置对象。

观察者模式在构建反应式用户界面方面特别有用。在一个项目中,我用它创建了一个实时通知系统,当新数据从服务器到达时,需要更新多个组件。

Shoping购物网源码
Shoping购物网源码

该系统采用多层模式开发,这个网站主要展示女装的经营,更易于网站的扩展和后期的维护,同时也根据常用的SQL注入手段做出相应的防御以提高网站的安全性,本网站实现了购物车,产品订单管理,产品展示,等等,后台实现了动态权限的管理,客户管理,订单管理以及商品管理等等,前台页面设计精致,后台便于操作等。实现了无限子类的添加,实现了动态权限的管理,支持一下一个人做的辛苦

下载

工厂模式已经在我需要根据用户输入或配置创建不同类型的对象的场景中证明了它的价值。例如,在内容管理系统中,我使用工厂根据用户选择创建不同类型的内容元素(文本、图像、视频)。

模块模式是我在大型应用程序中组织代码的首选解决方案。它使我能够创建具有清晰接口的独立模块,从而更轻松地管理依赖项并避免命名冲突。

原型模式在我需要创建许多类似对象的场景中非常有用。在一个游戏开发项目中,我使用此模式有效地创建具有共享行为的游戏实体的多个实例。

虽然这些模式很强大,但明智地使用它们也很重要。过度使用或误用设计模式可能会导致不必要的复杂性。在实施这些模式之前,我总是会考虑项目的具体需求以及团队对这些模式的熟悉程度。

根据我的经验,成功使用这些模式的关键是了解它们解决的问题以及何时应用它们。例如,单例模式非常适合管理全局状态,但如果过度使用,它可能会使单元测试变得更加困难。观察者模式非常适合解耦组件,但如果向主题添加太多观察者,可能会导致性能问题。

在实现这些模式时,我还密切关注性能方面的考虑。例如,当使用工厂模式时,我确保对象创建是高效的并且不会成为应用程序中的瓶颈。使用观察者模式,当不再需要观察者时,我会小心地删除它们,以防止内存泄漏。

我考虑的另一个重要方面是代码的可读性和可维护性。虽然这些模式可以极大地改进代码组织,但它们也可以使代码更加抽象,对于不熟悉这些模式的开发人员来说更难理解。我总是努力在使用模式解决问题和保持代码简单易懂之间找到适当的平衡。

总之,这五种 javascript 设计模式 - 单例、观察者、工厂、模块和原型 - 是构建可扩展和可维护应用程序的强大工具。它们为常见的编程挑战提供解决方案,并帮助以更高效和可重用的方式组织代码。然而,像任何工具一样,它们应该在正确的环境下谨慎使用。随着您对这些模式获得更多经验,您将了解何时以及如何在您的项目中最好地应用它们。

请记住,我们的目标不是为了设计模式本身而使用设计模式,而是为了解决实际问题并提高代码质量。在决定实现这些模式时,请始终考虑项目的具体需求、团队的技能以及代码库的长期可维护性。通过实践和经验,您会发现这些模式成为 javascript 开发工具包中的宝贵工具,帮助您创建更健壮、可扩展和可维护的应用程序。


我们的创作

一定要看看我们的创作:

投资者中心 | 智能生活 | 时代与回声 | 令人费解的谜团 | 印度教 | 精英开发 | js学校


我们在媒体上

科技考拉洞察 | 时代与回响世界 | 投资者中央媒体 | 令人费解的谜团 | 科学与时代媒介 | 现代印度教

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1126

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

192

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1637

2025.12.29

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

20

2026.01.19

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

514

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5306

2023.08.17

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

158

2026.01.28

热门下载

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

精品课程

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

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