当前位置: 首页 > news >正文

前端宝典十五:设计模式之前端开发5大设计原则

本文主要探讨前端开发设计原则:
单一职责原则
开闭原则
里氏替换原则
接口隔离原则
依赖倒置原则

一、单一职责原则(Single Responsibility Principle,SRP)

1、介绍

一个类应该只有一个引起它变化的原因。这意味着一个类应该只负责一项特定的任务,避免将过多的功能集中在一个类中,提高类的内聚性和可维护性。

2、代码实例

// 用户数据存储类,只负责用户数据的存储
class UserDataStorage {storeUserData(userData: any): void {// 存储用户数据的逻辑console.log(`Storing user data: ${userData}`);}
}// 用户数据验证类,只负责用户数据的验证
class UserDataValidator {validateUserData(userData: any): boolean {// 验证用户数据的逻辑return true;}
}

3、实际应用场景

在前端开发中,比如一个表单组件,可以将表单的渲染逻辑、数据验证逻辑和提交逻辑分别放在不同的类中。这样当需要修改表单的验证规则时,只需要修改验证类,而不会影响到渲染和提交逻辑。

二、开闭原则(Open/Closed Principle,OCP)

1、介绍

软件实体(类、模块、函数等)应该对扩展开放,对修改关闭。这意味着当有新的需求时,应该通过扩展现有代码来实现,而不是修改已有的代码。

2、代码实例

interface Shape {area(): number;
}class Rectangle implements Shape {constructor(private width: number, private height: number) {}area(): number {return this.width * this.height;}
}class Circle implements Shape {constructor(private radius: number) {}area(): number {return Math.PI * this.radius * this.radius;}
}class AreaCalculator {calculateArea(shapes: Shape[]): number {return shapes.reduce((total, shape) => total + shape.area(), 0);}
}

3、实际应用场景

在开发一个图表库时,可以定义一个抽象的图表接口,然后针对不同的图表类型实现这个接口。当需要添加新的图表类型时,只需要创建一个新的实现类,而不需要修改已有的代码。

三、里氏替换原则(Liskov Substitution Principle,LSP)

1、介绍

子类型必须能够替换掉它们的父类型。也就是说,在任何使用父类的地方,都可以用子类来替换而不会产生任何错误或异常。

2、代码实例

class Animal {move(): void {console.log('Animal is moving.');}
}class Bird extends Animal {move(): void {console.log('Bird is flying.');}
}class Dog extends Animal {move(): void {console.log('Dog is running.');}
}function makeAnimalMove(animal: Animal): void {animal.move();
}const bird = new Bird();
const dog = new Dog();makeAnimalMove(bird);
makeAnimalMove(dog);

3、实际应用场景

在开发一个游戏时,有一个角色类和各种子角色类。如果游戏中有一个函数接受角色类作为参数,那么可以传递任何子角色类的实例给这个函数,而不会影响游戏的逻辑。

四、接口隔离原则(Interface Segregation Principle,ISP)

1、介绍

客户端不应该依赖它不需要的接口。一个类对另一个类的依赖应该建立在最小的接口上。这可以避免实现不必要的方法,降低类之间的耦合度。

2、代码实例

interface Readable {read(): void;
}interface Writable {write(data: any): void;
}class File implements Readable, Writable {read(): void {console.log('Reading file.');}write(data: any): void {console.log('Writing to file.');}
}class Database implements Readable {read(): void {console.log('Reading from database.');}
}

3、实际应用场景

在前端开发中,如果有一个数据存储模块,可能有不同的存储方式,如本地存储和服务器存储。可以为它们分别定义不同的接口,避免在只需要本地存储功能的地方实现服务器存储的接口。

五、依赖倒置原则(Dependency Inversion Principle,DIP)

1、介绍

高层模块不应该依赖低层模块,二者都应该依赖于抽象。抽象不应该依赖于细节,细节应该依赖于抽象。这可以降低模块之间的耦合度,提高代码的可维护性和可扩展性。

2、代码实例

interface DataSource {fetchData(): any;
}class DatabaseSource implements DataSource {fetchData(): any {return { data: 'from database' };}
}class FileSource implements DataSource {fetchData(): any {return { data: 'from file' };}
}class DataProcessor {constructor(private dataSource: DataSource) {}processData(): void {const data = this.dataSource.fetchData();console.log(data);}
}

3、实际应用场景

在开发一个前端应用时,数据获取模块不应该直接依赖于具体的数据来源(如某个特定的 API),而是应该依赖于一个抽象的数据获取接口。这样当数据来源发生变化时,只需要修改具体的数据来源实现类,而不会影响到应用的其他部分。

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Vue3搜索框(InputSearch)
  • 第七届MathorCup高校数学建模挑战赛-A题:基于改进的神经网络和混沌时间序列预测控制高炉炼铁过程
  • 工作中的所思所想(一)
  • 搭建自己的金融数据源和量化分析平台(七):定时更新上市公司所属行业门类及大类
  • Web中的Cookie与Session
  • 对象存储服务MinIO
  • Python如何度量字符串长度,代码示例
  • CREO中边界混合命令如何设置影响曲线?
  • NLP从零开始------14.文本中阶序列处理之语言模型(2)
  • 浅析裸土检测算法的实际应用及裸土检测算法源码样本
  • debian12 - 修改SSH端口连接回包
  • RISC-V全志D1sCVBS套件
  • JAVA之MAC详解以及子线程MDC传递
  • 飞书怎么关联任意两段话
  • 中医文化推广者魏玉龙任国家医药卫生行业继续教育培训基地培训中心主任
  • [数据结构]链表的实现在PHP中
  • GitUp, 你不可错过的秀外慧中的git工具
  • Java-详解HashMap
  • Js基础知识(四) - js运行原理与机制
  • leetcode讲解--894. All Possible Full Binary Trees
  • node-sass 安装卡在 node scripts/install.js 解决办法
  • oschina
  • Redis学习笔记 - pipline(流水线、管道)
  • Yii源码解读-服务定位器(Service Locator)
  • 前端知识点整理(待续)
  • 深度学习在携程攻略社区的应用
  • 实战:基于Spring Boot快速开发RESTful风格API接口
  • 用Node EJS写一个爬虫脚本每天定时给心爱的她发一封暖心邮件
  • ​【已解决】npm install​卡主不动的情况
  • ​Java并发新构件之Exchanger
  • ​学习笔记——动态路由——IS-IS中间系统到中间系统(报文/TLV)​
  • ###C语言程序设计-----C语言学习(6)#
  • #Linux杂记--将Python3的源码编译为.so文件方法与Linux环境下的交叉编译方法
  • #调用传感器数据_Flink使用函数之监控传感器温度上升提醒
  • ( )的作用是将计算机中的信息传送给用户,计算机应用基础 吉大15春学期《计算机应用基础》在线作业二及答案...
  • ( 用例图)定义了系统的功能需求,它是从系统的外部看系统功能,并不描述系统内部对功能的具体实现
  • (1)(1.13) SiK无线电高级配置(五)
  • (1)虚拟机的安装与使用,linux系统安装
  • (2)(2.10) LTM telemetry
  • (4)STL算法之比较
  • (Bean工厂的后处理器入门)学习Spring的第七天
  • (C#)Windows Shell 外壳编程系列4 - 上下文菜单(iContextMenu)(二)嵌入菜单和执行命令...
  • (C语言)球球大作战
  • (Java入门)抽象类,接口,内部类
  • (JSP)EL——优化登录界面,获取对象,获取数据
  • (Redis使用系列) Springboot 实现Redis 同数据源动态切换db 八
  • (二)延时任务篇——通过redis的key监听,实现延迟任务实战
  • (附源码)springboot工单管理系统 毕业设计 964158
  • (附源码)基于SpringBoot和Vue的厨到家服务平台的设计与实现 毕业设计 063133
  • (使用vite搭建vue3项目(vite + vue3 + vue router + pinia + element plus))
  • (转载)CentOS查看系统信息|CentOS查看命令
  • (转载)利用webkit抓取动态网页和链接
  • .【机器学习】隐马尔可夫模型(Hidden Markov Model,HMM)
  • .NET CF命令行调试器MDbg入门(二) 设备模拟器
  • .NET MVC、 WebAPI、 WebService【ws】、NVVM、WCF、Remoting