0

0

JavaScript设计原则_SOLID应用实践

狼影

狼影

发布时间:2025-11-23 20:02:02

|

478人浏览过

|

来源于php中文网

原创

solid原则在javascript中同样适用。1. 单一职责:函数应只做一件事,如拆分用户处理逻辑;2. 开放封闭:通过策略模式扩展功能而不修改原代码;3. 里氏替换:子类不破坏父类契约,确保行为一致;4. 接口隔离:避免大而全的配置,使用细粒度函数;5. 依赖反转:依赖抽象而非具体实现,通过注入提升可测性与解耦。合理应用可提升代码质量。

javascript设计原则_solid应用实践

在JavaScript开发中,尽管它是一门灵活且动态的语言,但随着项目规模扩大,代码的可维护性、可扩展性和可测试性变得至关重要。SOLID原则作为面向对象设计的五大基石,虽然最初针对的是静态类型语言,但在JavaScript中同样具有指导意义。合理应用这些原则,能帮助我们写出更清晰、更健壮的代码。

单一职责原则(SRP)

一个模块或函数应该只有一个改变的理由。 在JavaScript中,这意味着每个函数、类或模块应专注于完成一件事。

例如,一个处理用户数据的函数不应同时负责格式化输出和发送网络请求:

// ❌ 违反SRP function saveUser(userData) { const validated = validate(userData); const formatted = formatUserForDisplay(validated); logToConsole(formatted); return fetch('/api/users', { method: 'POST', body: JSON.stringify(validated) }); } // ✅ 符合SRP function validateUser(userData) { return validate(userData); } function formatUser(userData) { return formatUserForDisplay(userData); } function logUser(userData) { logToConsole(userData); } function saveUserToApi(userData) { return fetch('/api/users', { method: 'POST', body: JSON.stringify(userData) }); }

拆分职责后,每个函数更易测试、复用和维护。

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

开放封闭原则(OCP)

软件实体应对扩展开放,对修改关闭。 我们应能在不改动已有代码的前提下添加新功能。

在JavaScript中,可以通过高阶函数、策略模式或依赖注入实现:

class PaymentProcessor { constructor(strategy) { this.strategy = strategy; // 策略注入 } process(amount) { return this.strategy.handlePayment(amount); } } const creditCardStrategy = { handlePayment: (amount) => `Paid $${amount} by credit card` }; const paypalStrategy = { handlePayment: (amount) => `Paid $${amount} via PayPal` }; // 新增支付方式无需修改PaymentProcessor

通过传入不同策略对象,系统可在运行时扩展行为,而核心逻辑保持不变。

里氏替换原则(LSP)

子类型必须能够替换其基类型。 在JavaScript这类原型继承语言中,这提醒我们:重写方法时不能破坏原有契约。

ThinkPHP3.2.3完全开发
ThinkPHP3.2.3完全开发

ThinkPHP是一个快速、简单的基于MVC和面向对象的轻量级PHP开发框架,遵循Apache2开源协议发布,从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,尤其注重开发体验和易用性,并且拥有众多的原创功能和特性,为WEB应用开发提供了强有力的支持。 3.2版本则在原来的基础上进行一些架构的调整,引入了命名空间支持和模块化的完善,为大型应用和模块化开发提供了更多的便利。

下载

例如,若父类方法返回Promise,子类也不应改为同步返回:

class Animal { makeSound() { throw new Error("Must be implemented"); } } class Dog extends Animal { makeSound() { return "Woof"; } } class Duck extends Animal { makeSound() { return "Quack"; } } // 所有子类都能在使用Animal的地方无缝替换 function animalChorus(animals) { return animals.map(animal => animal.makeSound()); }

只要接口一致,调用方无需关心具体类型。

接口隔离原则(ISP)

客户端不应被强迫依赖它不需要的接口。 JavaScript没有原生接口类型,但我们可用对象结构模拟。

避免创建“大而全”的配置对象或类:

// ❌ 强迫用户传递无用字段 function createModal(config) { if (config.isDraggable) enableDrag(config.el); if (config.hasCloseButton) addCloseButton(config.el); // ... } // ✅ 拆分为小的、专注的选项 function withDraggable(el) { /*...*/ } function withCloseButton(el) { /*...*/ } // 组合使用 withDraggable(modalEl); withCloseButton(modalEl);

更细粒度的函数让使用者只引入所需功能。

依赖反转原则(DIP)

高层模块不应依赖低层模块,二者都应依赖抽象;抽象不应依赖细节,细节应依赖抽象。

在JavaScript中,可通过依赖注入实现:

class Logger { log(message) { console.log(message); } } class UserService { constructor(logger) { this.logger = logger; // 依赖抽象的日志接口 } createUser(name) { // 业务逻辑 this.logger.log(`User ${name} created`); } } // 可替换为文件日志、远程日志等 const userService = new UserService(new Logger());

这样,业务逻辑与具体实现解耦,便于测试(如注入mock logger)和演进。

基本上就这些。SOLID不是教条,而是提升代码质量的思维工具。在JavaScript这种灵活语言中,结合函数式编程、组合优于继承等理念,能让SOLID原则发挥更大价值。关键是保持代码清晰、低耦合、易于演化。不复杂但容易忽略。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

455

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

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

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

334

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

82

2025.09.10

if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

846

2023.08.22

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

58

2025.09.05

java面向对象
java面向对象

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

63

2025.11.27

go语言 面向对象
go语言 面向对象

本专题整合了go语言面向对象相关内容,阅读专题下面的文章了解更多详细内容。

58

2025.09.05

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

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

3

2026.03.11

热门下载

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

精品课程

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

共58课时 | 6万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.4万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

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

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