JavaScript高级:常见设计模式
设计模式是在软件开发中重复出现的问题的解决方案,它们是经过验证的、被广泛接受的最佳实践。设计模式可以让我们避免重复造轮子,提高代码质量和可维护性。在本文中,我们将介绍几种常见的设计模式,以及它们的实现和应用。
1. 单例模式
单例模式保证一个类只有一个实例,并提供全局访问点。在 JavaScript 中,可以通过闭包来实现单例模式。
const Singleton = (function() {let instance;function createInstance() {// 创建实例的逻辑return {};}return {getInstance: function() {if (!instance) {instance = createInstance();}return instance;}};
})();const instance1 = Singleton.getInstance();
const instance2 = Singleton.getInstance();
console.log(instance1 === instance2); // 输出:true
2. 工厂模式
工厂模式用于创建对象的方法,将对象的创建与使用分离,降低耦合度。在 JavaScript 中,可以通过构造函数或者简单工厂来实现工厂模式。
class Product {constructor(name) {this.name = name;}
}class ProductFactory {createProduct(name) {return new Product(name);}
}const factory = new ProductFactory();
const product = factory.createProduct('A');
3. 观察者模式
观察者模式定义对象间的一种一对多依赖关系,当一个对象状态发生改变时,其依赖者都会收到通知并自动更新。在 JavaScript 中,可以使用发布-订阅模式来实现观察者模式。
class Subject {constructor() {this.observers = [];}addObserver(observer) {this.observers.push(observer);}notify(message) {this.observers.forEach(observer => observer.update(message));}
}class Observer {update(message) {console.log(`Received message: ${message}`);}
}const subject = new Subject();
const observer1 = new Observer();
const observer2 = new Observer();subject.addObserver(observer1);
subject.addObserver(observer2);subject.notify('Hello, observers!');
4. 策略模式
策略模式定义一系列算法,并将其封装成策略类,使它们可以互相替换。在 JavaScript 中,可以使用对象字面量来实现策略模式。
const discountStrategies = {normal: amount => amount,vip: amount => amount * 0.8,premium: amount => amount * 0.7
};function calculateDiscount(strategy, amount) {return discountStrategies[strategy](amount);
}const normalPrice = 100;
const vipPrice = calculateDiscount('vip', normalPrice);
5. 装饰者模式
装饰者模式动态地将责任附加到对象上,以扩展其功能。在 JavaScript 中,可以通过继承或组合来实现装饰者模式。
class Coffee {cost() {return 10;}
}class MilkDecorator {constructor(coffee) {this.coffee = coffee;}cost() {return this.coffee.cost() + 5;}
}class SugarDecorator {constructor(coffee) {this.coffee = coffee;}cost() {return this.coffee.cost() + 2;}
}let coffee = new Coffee();
coffee = new MilkDecorator(coffee);
coffee = new SugarDecorator(coffee);console.log(coffee.cost()); // 输出:17
设计模式是开发者们多年实践的经验总结,它们可以帮助我们解决复杂的问题并提高代码的可维护性。单例模式、工厂模式、观察者模式、策略模式、装饰者模式等都是常见且实用的设计模式。通过理解这些模式的实现和应用,你将能够更好地构建优雅、可扩展的应用程序,提升你的编程艺术水平。无论你是初学者还是有经验的开发者,掌握设计模式,都将让你在编程的世界中更加游刃有余,创造出更加出色的作品!
相关文章:
JavaScript高级:常见设计模式
设计模式是在软件开发中重复出现的问题的解决方案,它们是经过验证的、被广泛接受的最佳实践。设计模式可以让我们避免重复造轮子,提高代码质量和可维护性。在本文中,我们将介绍几种常见的设计模式,以及它们的实现和应用。 1. 单例…...
32bit国产低功耗无线MCU芯片
超低功耗无线MCU芯片MS1642,集成了高性能的32位ARMCortex-M0内核,宽电压工作范围的MCU。嵌入高达64Kbytes高可靠Flash和8Kbytes SRAM存储器,最高工作频率32MHz。芯片集成多路I2C、USART等通讯外设,1路12bit ADC,5个16b…...
scope组件穿透
今天我们以单选框为例来探究一下样式的穿透问题 1.代码 <template><div class""><el-radio v-model"radio" label"1">备选项</el-radio><el-radio v-model"radio" label"2">备选项</el-r…...
分类预测 | Python实现LR逻辑回归多输入分类预测
分类预测 | Python实现LR逻辑回归多输入分类预测 目录 分类预测 | Python实现LR逻辑回归多输入分类预测基本介绍模型描述源码设计学习小结参考资料基本介绍 逻辑回归是一种广义线性的分类模型且其模型结构可以视为单层的神经网络,由一层输入层、一层仅带有一个sigmoid激活函数…...
【微信小程序】通过使用 wx.navigateTo方法进行页面跳转,跳转后的页面中通过一些方式回传值给原页面
以下是几种常见的回传值的方式: 使用 wx.navigateTo 方法传递参数: 在跳转时,可以在目标页面的 URL 中携带参数,然后在目标页面的 onLoad 方法中获取参数,并在目标页面中进行处理。例如: // 原页面跳转到目…...
DIP: Spectral Bias of DIP 频谱偏置解释DIP
On Measuring and Controlling the Spectral Bias of the Deep Image Prior 文章目录 On Measuring and Controlling the Spectral Bias of the Deep Image Prior1. 方法原理1.1 动机1.2 相关概念1.3 方法原理频带一致度量与网络退化谱偏移和网络结构的关系Lipschitz-controlle…...
【考研数学】概率论与梳理统计 | 第一章——随机事件与概率(1)
文章目录 一、随机试验与随机事件1.1 随机试验1.2 样本空间1.3 随机事件 二、事件的运算与关系2.1 事件的运算2.2 事件的关系2.3 事件运算的性质 三、概率的公理化定义与概率的基本性质3.1 概率的公理化定义3.2 概率的基本性质 写在最后 一、随机试验与随机事件 1.1 随机试验 …...
LeetCode 36题:有效的数独
题目 请你判断一个 9 x 9 的数独是否有效。只需要 根据以下规则 ,验证已经填入的数字是否有效即可。 数字 1-9 在每一行只能出现一次。数字 1-9 在每一列只能出现一次。数字 1-9 在每一个以粗实线分隔的 3x3 宫内只能出现一次。(请参考示例图ÿ…...
word横向页面侧面页码设置及转pdf后横线变竖线的解决方案
在处理材料的时候,会遇到同一个文档里自某一页开始,页面布局是横向的,这时候页码要设置在侧面,方法是双击页脚,然后在word工具栏上选择“插入”——>“文本框”——>“绘制竖版文本框”,然后在页面左…...
华为OD机试 - 字符串划分(Java JS Python)
题目描述 给定一个小写字母组成的字符串 s,请找出字符串中两个不同位置的字符作为分割点,使得字符串分成三个连续子串且子串权重相等,注意子串不包含分割点。 若能找到满足条件的两个分割点,请输出这两个分割点在字符串中的位置下标,若不能找到满足条件的分割点请返回0,…...
使用 `nmcli` 在 CentOS 8 上添加永久路由
CentOS 8 使用 NetworkManager 作为默认的网络管理工具,因此我们可以使用 nmcli 工具来实现相同的目标。使用 nmcli 可以更加直观地管理路由,并且更符合 CentOS 8 的默认网络管理方式。 以下是使用 nmcli 在 CentOS 8 上添加永久路由的步骤:…...
Java基础五之for循环小练习
加油,新时代大工人! 一、Java基础之算术运算符 二、Java基础之类型转换 三、Java基础之【字符串操作以及自增自减操作】 四、Java基础之赋值运算符和关系运算符 package base;import java.io.InputStream; import java.util.Scanner;/*** author wh* date 2023年08…...
解决 Python RabbitMQ/Pika 报错:pop from an empty deque
使用 python 的 pika 包连接rabbitmq,代码如下: import pika import threading import timedef on_message(channel, method_frame, header_frame, body):print(fon_message thread id: {threading.get_ident()})delivery_tag method_frame.delivery_t…...
观察者模式实战
场景 假设创建订单后需要发短信、发邮件等其它的操作,放在业务逻辑会使代码非常臃肿,可以使用观察者模式优化代码 代码实现 自定义一个事件 发送邮件 发送短信 最后再创建订单的业务逻辑进行监听,创建订单 假设后面还需要做其它的…...
035_小驰私房菜_Qualcomm账号注册以及提case流程
全网最具价值的Android Camera开发学习系列资料~ 作者:8年Android Camera开发,从Camera app一直做到Hal和驱动~ 欢迎订阅,相信能扩展你的知识面,提升个人能力~ 一、账号注册 1)登陆高通网站Wireless Technology & Innovation | Mobile Technology | Qualcomm, 采用…...
uniapp input输入框placeholder文本右对齐
input输入框placeholder文本右对齐 给input标签加上placeholder-class,这个是给placeholder设置样式,右对齐这就是text-align:right;字体颜色之类依次编辑即可。...
分布式监控平台—zabbix
前言一、zabbix概述1.1 什么是zabbix1.2 zabbix的监控原理1.3 zabbix常见五个应用程序1.4 zabbix的监控模式1.5 监控架构1.5.1 C/S(server—client)1.5.2 server—proxy—client1.5.3 master—node—client 二、部署zabbix2.1 部署 zabbix server 端2.2 …...
【leetcode】第一章数组-2
977. 有序数组的平方 简单的方法是平方后使用排序方法第2种方法是双指针方法,从两边进行判断,将最大的从后往前放 public static int[] sortedSquares(int[] nums) {// 输入:nums [-4,-1,0,3,10]// 输出:[0,1,9,16,100]// 解释…...
程序使用Microsoft.XMLHTTP对象请求https时出错解决
程序中使用Microsoft.XMLHTTP组件请求https时出现如下错误: 出错程序代码示例: strUrl "https://www.xxx.com/xxx.asp?id11" dim objXmlHttp set objXmlHttp Server.CreateObject("Microsoft.XMLHTTP") objXmlHttp.open "…...
Linux安装配置nginx+php搭建
Linux安装配置nginxphp搭建 文章目录 Linux安装配置nginxphp搭建1.nginx源码包编译环境和安装相应的依赖1.1 安装编译环境1.2 安装pcre库、zlib库和openssl库 2.安装nginx2.1 在[nginx官网](https://nginx.org/en/download.html)上获取源码包并进行下载2.2 进行解压编译 3.启动…...
3个步骤解锁《艾尔登法环》帧率限制:告别60帧束缚的终极指南
3个步骤解锁《艾尔登法环》帧率限制:告别60帧束缚的终极指南 【免费下载链接】EldenRingFpsUnlockAndMore A small utility to remove frame rate limit, change FOV, add widescreen support and more for Elden Ring 项目地址: https://gitcode.com/gh_mirrors/…...
Pixel Aurora Engine效果展示:从Prompt到像素画的10组高质量生成对比
Pixel Aurora Engine效果展示:从Prompt到像素画的10组高质量生成对比 1. 像素艺术的新纪元 在数字艺术创作领域,Pixel Aurora Engine带来了一场像素艺术的革命。这款基于AI扩散模型的工作站,将复古的8-bit美学与现代AI技术完美融合…...
MobaXterm高效运维:通过SSH图形化管理远程Pixel Couplet Gen服务器
MobaXterm高效运维:通过SSH图形化管理远程Pixel Couplet Gen服务器 1. 为什么选择MobaXterm进行远程运维 对于运维人员来说,管理远程服务器是日常工作的重要组成部分。特别是当我们需要管理部署在星图GPU服务器上的Pixel Couplet Gen这类AI服务时&…...
EcomGPT-7B在Unity引擎中的应用:打造沉浸式虚拟电商购物助手
EcomGPT-7B在Unity引擎中的应用:打造沉浸式虚拟电商购物助手 想象一下,你走进一个由Unity引擎构建的、光影绚丽的3D虚拟商场。货架上琳琅满目,商品细节纤毫毕现。这时,一位虚拟导购员微笑着向你走来,你随口问了一句&a…...
DeepSeek-OCR-2部署案例:私有云OpenStack平台OCR服务容器化部署
DeepSeek-OCR-2部署案例:私有云OpenStack平台OCR服务容器化部署 1. 项目背景与价值 在数字化转型的浪潮中,文档数字化处理成为企业提升效率的关键环节。传统的OCR技术往往面临识别精度不足、处理速度慢、部署复杂等问题,特别是在私有云环境…...
SAP FI(财务会计)核心基础中的会计科目表(Chart of Accounts)设计与配置
SAP FI(财务会计)核心基础中的会计科目表(Chart of Accounts)设计与配置。这是一个非常关键的 SAP 财务模块主题,我会从基础概念到实际配置进行全面讲解。一、会计科目表基础概念1.1 什么是会计科目表(Char…...
etcd Raft 实现:分布式一致性核心原理
# etcd Raft 实现:分布式一致性核心原理> **源码版本**: etcd 3.5.9 | Go 1.21.5 > **阅读时间**: 约 25 分钟 > **难度**: ⭐⭐⭐⭐## 📋 引言在分布式系统中,如何让多个节点达成一致是一个经典难题。etcd 作为云原生时代的核心…...
jQuery元素遍历与条件检测
在网页开发中,经常会遇到需要检测多个元素状态并基于此做出某种响应的情况。本文将结合一个具体的实例,详细介绍如何使用jQuery来遍历DOM元素,并根据它们的CSS属性值来决定是否显示一条消息。 问题描述 假设我们有一个父容器div,其内部包含多个子div元素,我们希望检查这…...
Mysql的行级锁到底是怎么加的?醒
1. 架构背景与演进动力 1.1 从单体到碎片化:.NET 的开源征程 在.NET Framework 时代,构建系统主要围绕 Windows 操作系统紧密集成,采用传统的封闭式开发模式。然而,随着.NET Core 的推出,微软开启了彻底的开源与跨平台…...
CCC3.0数字钥匙系统架构解析:从蓝牙OOB配对到多设备互操作性
1. 从机械钥匙到数字钥匙的技术演进 记得十年前我第一次买车时,销售递给我的是一把沉甸甸的机械钥匙,上面还挂着一个印着品牌logo的钥匙扣。那时候根本想不到,短短几年后我们就能用手机解锁汽车。这种变化背后,是CCC(C…...
