百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

阿里前端架构设计师细讲前端设计模式,网友:666刷起来

ccwgpt 2024-10-12 02:45 17 浏览 0 评论

作为一个前端新人,学习了设计模式以后,希望能从源头上,用浅显易懂的语言来解释它。当然不一定是正确的,只是我个人对设计模式的一点浅显理解。

创建型设计模式

创建型设计模式:故名思意,这些模式都是用来创建实例对象的。

单例模式:首先我们需要理解什么是单例。

:指的是一个。

:指的是创建的实例。

单例:指的是创建的总是同一个实例。也就是使用类创建的实例始终是相同的。

我们先看下面的一段代码:

class Person{
 constructor(){}
}
let p1 = new Person();
let p2 = new Person();
console.log(p1===p2) //false

上面这段代码,定义了一个Person类,通过这个类创建了两个实例,我们可以看到最终这两个实例是不相等的。也就是说,通过同一个类得到的实例不是同一个(这本就是理所应当),但是如果我们想始终得到的是同一个实例,那么这就是**单例模式**。那么应该如何实现单例模式了:

想要实现单例模式,我们需要注意两点:

  1. 需要使用return。使用new的时候如果没有手动设置return,那么会默认返回this。但是,我们这里要使得每次返回的实例相同,也就是需要手动控制创建的对象,因此这里需要使用return
  2. 我们需要每次return的是同一个对象。也就是说实际上在第一次实例的时候,需要把这个实例保存起来。再下一个实例的时候,直接return这个保存的实例。因此,这里需要用到闭包了

代码实现如下:

(function(){
 let instance = null;
 return class{
 constructor(){
 if(!instance){
 //第一次创建实例,那么需要把实例保存
 instance = this;
 }else{
 return instance;
 }
 }
 }
})()
let p3= new Person();
let p4 = new Person();
console.log(p3===p4) //true
 

从上面的代码中,我们可以看到在闭包中,使用instance变量来保存创建的实例,每次返回的都是第一次创建的实例。这样的话就实现了无论创建多少次,创建的都是同一个实例,这就是单例模式。

工厂模式

对于工厂来说,我们的印象可能是里面具有各种各样的模具,根据你想要的产品的模型,生产你需要的产品。比如说你请工厂帮你加工一个产品,你只需要告诉工厂你这个产品的结构,工厂就会有对应的模型帮你生产,你不需要去关心它具体是怎么加工的。同样工厂模式也是这样,(工厂模式也是创建型设计模式,用于创建实例对象的)你不需要自己去找对应的类来创建实例,你只需要告诉工厂类你要创建什么实例,他就会返回你需要的实例对象。

工厂模式根据抽象程度的不同,分为三种:

1. 简单工厂模式

2. 工厂方法模式

3. 抽象工厂模式

简单工厂模式

定义:定义一个工厂类,通过工厂函数,根据传入的参数不同,返回不同的实例。看下面的代码:

//学生类
class Student{
 constructor(name,age){
 this.name = name;
 this.age = age;
 }
 showName(){
 console.log(this.name)
 }
}
 
//老师类
class Teacher{
 constructor(name,age){
 this.name = name;
 this.age = age;
 }
 showName(){
 console.log(this.name)
 }
}
 
//警察类
class Policeman{
 constructor(name,age){
 this.name = name;
 this.age = age;
 }
 showName(){
 console.log(this.name)
 }
}
根据类创建对象
const s1 = new Student('王小一',24);
const t1 = new Teacher('李一老师',39);
const p1= new Policeman('张一警官',40);

我们可以看到,上面代码中定义了三个类,学生类,老师类和警察类。而且它们具有相同的属性和方法。当我们需要创建学生实例时,我们调用学生类。当我们需要创建老师实例时,我们调用老师类,当我们需要创建警察实例,我们调用警察类。假设我们有更多的人物类,它们具有相同的功能,那么当我们需要创建实例的时候,我们同样需要调用相对应的类。事实上,这些类实现的都是相同的功能,那么我们可不可以把所有的创建这些人物实例都通过一个类来实现了。我们尝试将代码修改为如下:

//学生类
class Student{
 constructor(name,age){
 this.name = name;
 this.age = age;
 }
 showName(){
 console.log(this.name)
 }
}
 
//老师类
class Teacher{
 constructor(name,age){
 this.name = name;
 this.age = age;
 }
 showName(){
 console.log(this.name)
 }
}
 
//警察类
class Policeman{
 constructor(name,age){
 this.name = name;
 this.age = age;
 }
 showName(){
 console.log(this.name)
 }
}
 
//工厂类
class Factory{
 let obj = null;
 //工厂函数
 constructor(role,name,age){
 switch(role){
 case 'student':
 obj = new Student(name,age);
 break;
 case 'teacher':
 obj = new Teacher(name,age);
 break;
 case 'policeman':
 obj = new Policeman(name,age);
 break;
 }
 }
 return obj;
}
 
const s2 = new Factory('student','王小二',25);
const t2 = new Factory('teacher','李二老师',39);
const p2 = new Factory('policeman','张二警官',40);

从上面的代码中,我们可以看到我们同样定义了学生类,老师类,警察类这三个类,但是我们创建实例时通过Factory这个类,不再通过相对应的人物类了。这个Factory类就是工厂类,我们观察工厂类的实现,发现里面是一个工厂函数(这里直接使用了constructor,也可以自己定义工厂函数),通过传递给工厂函数的参数不同,返回不同的实例。这就是简单工厂模式。

简单工厂模式总结

实现:从上面的代码中我们可以知道,所谓简单工厂模式就是一个工厂类和一个工厂函数,通过传入参数的不同,返回不同的实例。

特点:1. 需要创建的类较少,因为需要根据传入的参数来判断返回的实例,如果类太多,那么就会导致逻辑复杂。2. 不需要关注实例的创建过程,只需要传入相对应的值即可。

适用场景:举一个生活中实际的使用场合,假如我们上体育课需要去拿篮球,足球和排球,我们可以自己去一个一个找对应的球(类似于上面通过自己来创建对象),也可以通过管理员,告诉管理员需要什么样的球,至于管理员是怎么找到这个相对应的球,就与我们不相关了。这个管理员就是工厂类。

缺点:从简单工厂模式的特点中我们可以知道,简单工厂模式适合于创建的类较少,一旦需要的类较多,逻辑就会复杂。而且一旦需要添加新的类,就得重新修改工厂类,这样显得非常不方便。

工厂方法模式

工厂方法模式是对简单工厂的进一步优化, 在工厂方法模式中,我们不再提供一个统一的工厂类来创建所有的对象,而是针对不同的对象提供不同的工厂。也就是说每个对象都有一个与之对应的工厂。说的好像挺复杂,其实在我看来他就是解决简单工厂模式存在的不方便添加新的类,因为添加新的类以后需要修改工厂函数。而工厂方法模式就是解决这个问题,看下面的代码:

let Factory = (function(){
 let s = {
 Student(name,age){
 this.name = name;
 this.age = age;
 return this;
 },
 Teacher(name,age){
 this.name = name;
 this.age = age;
 return this;
 },
 Policeman(name,age){
 this.name = name;
 this.age = age;
 return this;
 },
 //在这里添加新的类
 Doctor(name,age){
 this.name = name;
 this.age = age;
 return this;
 }
 }
 
 return class {
 //工厂函数根据传进来的来的参数不同而不同。
 constructor(type,name,age){
 if(s.hasOwnProperty(type)){
 return s[type].call(this,name,age)
 }else{
 throw new Error(`不存在${type}类`)
 }
 
 }
 }
 
 
})()
 
let s3 = new Factory('Student','王小三',25);
let t3 = new Factory('Teacher','李三老师',25);
let p3 = new Factory('Policeman','张三警官',28);
let d3 = new Factory('Doctor','杨医生',33);

从上面的代码中,我们可以看到,相比于简单工厂函数,工厂方法模式的工厂函数不是固定的,而是根据type不同而不同。当我们需要添加新的类时,只需要在s对象中添加实例即可,不需要修改工厂函数。这样的话就不会因为需要添加新的类,而修改过多的代码逻辑。这就是工厂方法模式。其实就是对简单工厂模式的优化而已

学web前端其实很简单,下面是小编整理的一整套系统的web前端学习教程(部分截图),关注小编头条号,私信【前端】即可免费领取!

相关推荐

详解DNFSB2毒王的各种改动以及大概的加点框架

首先附上改动部分,然后逐项分析第一个,毒攻掌握技能意思是力量智力差距超过15%的话差距会被强行缩小到15%,差距不到15%则无效。举例:2000力量,1650智力,2000*0.85=1700,则智力...

通篇干货!纵观 PolarDB-X 并行计算框架

作者:玄弟七锋PolarDB-X面向HTAP的混合执行器一文详细说明了PolarDB-X执行器设计的初衷,其初衷一直是致力于为PolarDB-X注入并行计算的能力,兼顾TP和AP场景,逐渐...

字节新推理模型逆袭DeepSeek,200B参数战胜671B,豆包史诗级加强

梦晨发自凹非寺量子位|公众号QbitAI字节最新深度思考模型,在数学、代码等多项推理任务中超过DeepSeek-R1了?而且参数规模更小。同样是MoE架构,字节新模型Seed-Thinkin...

阿里智能化研发起飞!RTP-LLM 实现 Cursor AI 1000 token/s 推理技术揭秘

作者|赵骁勇阿里巴巴智能引擎事业部审校|刘侃,KittyRTP-LLM是阿里巴巴大模型预测团队开发的高性能LLM推理加速引擎。它在阿里巴巴集团内广泛应用,支撑着淘宝、天猫、高德、饿...

多功能高校校园小程序/校园生活娱乐社交管理小程序/校园系统源码

校园系统通常是为学校、学生和教职工提供便捷的数字化管理工具。综合性社交大学校园小程序源码:同城校园小程序-大学校园圈子创业分享,校园趣事,同校跑腿交友综合性论坛。小程序系统基于TP6+Uni-app...

婚恋交友系统nuiAPP前端解决上传视频模糊的问题

婚恋交友系统-打造您的专属婚恋交友平台系统基于TP6+Uni-app框架开发;客户移动端采用uni-app开发,管理后台TH6开发支持微信公众号端、微信小程序端、H5端、PC端多端账号同步,可快速打包...

已节省数百万GPU小时!字节再砍MoE训练成本,核心代码全开源

COMET团队投稿量子位|公众号QbitAI字节对MoE模型训练成本再砍一刀,成本可节省40%!刚刚,豆包大模型团队在GitHub上开源了叫做COMET的MoE优化技术。COMET已应用于字节...

通用电气完成XA102发动机详细设计审查 将为第六代战斗机提供动力

2025年2月19日,美国通用电气航空航天公司(隶属于通用电气公司)宣布,已经完成了“下一代自适应推进系统”(NGAP)计划下提供的XA102自适应变循环发动机的详细设计审查阶段。XA102是通用电气...

tpxm-19双相钢材质(双相钢f60材质)

TPXM-19双相钢是一种特殊的钢材,其独特的化学成分、机械性能以及广泛的应用场景使其在各行业中占有独特的地位。以下是对TPXM-19双相钢的详细介绍。**化学成分**TPXM-19双相钢的主要化学成...

thinkphp6里怎么给layui数据表格输送数据接口

layui官网已经下架了,但是产品还是可以使用。今天一个朋友问我怎么给layui数据表格发送数据接口,当然他是学前端的,后端不怎么懂,自学了tp框架问我怎么调用。其实官方文档上就有相应的数据格式,js...

完美可用的全媒体广告精准营销服务平台PHP源码

今天测试了一套php开发的企业网站展示平台,还是非常不错的,下面来给大家说一下这套系统。1、系统架构这是一套基于ThinkPHP框架开发的HTML5响应式全媒体广告精准营销服务平台PHP源码。现在基于...

一对一源码开发,九大方面完善基础架构

以往的直播大多数都是一对多进行直播社交,弊端在于不能满足到每个用户的需求,会降低软件的体验感。伴随着用户需求量的增加,一对一直播源码开始出现。一个完整的一对一直播流程即主播发起直播→观看进入房间观看→...

Int J Biol Macromol .|交联酶聚集体在分级共价有机骨架上的固定化:用于卤代醇不对称合成的高稳定酶纳米反应器

大家好,今天推送的文章发表在InternationalJournalofBiologicalMacromolecules上的“Immobilizationofcross-linkeden...

【推荐】一款开源免费的 ChatGPT 聊天管理系统,支持PC、H5等多端

如果您对源码&技术感兴趣,请点赞+收藏+转发+关注,大家的支持是我分享最大的动力!!!项目介绍GPTCMS是一款开源且免费(基于GPL-3.0协议开源)的ChatGPT聊天管理系统,它基于先进的GPT...

高性能计算(HPC)分布式训练:训练框架、混合精度、计算图优化

在深度学习模型愈发庞大的今天,分布式训练、高效计算和资源优化已成为AI开发者的必修课。本文将从数据并行vs模型并行、主流训练框架(如PyTorchDDP、DeepSpeed)、混合精度训练(...

取消回复欢迎 发表评论: