js设计模式(部分)
单例模式
一个类只有一个实例,无论new多少次都是这一个实例,且提供全局访问

function VirtualDom(name, age) { this.name = name, this.age = age } VirtualDom.getInstance = (function(){ let instance; return function(name, age) { if (!(instance instanceof VirtualDom)){ instance = new VirtualDom(name, age); } return instance; } })(); let obj1 = VirtualDom.getInstance('admin', 12); let obj2 = VirtualDom.getInstance('root', 18); console.log(obj1 == obj2); //true console.log(obj1);//VirtualDom {name: 'admin', age: 12} console.log(obj2);//VirtualDom {name: 'admin', age: 12}
静态工厂模式
由一个工厂对象来创建某一种产品对象类的实例,主要用来创建同一个类的对象
调用需要的功能到工厂里获取,无需关注创建过程

class API { procure() { throw new Error('该方法不能直接调用'); } make() { throw new Error('该方法不能直接调用'); } package() { throw new Error('该方法不能直接调用'); } sell() { throw new Error('该方法不能直接调用'); } } class Phone extends API { typeName = '手机'; procure() { console.log(`${this.typeName} 正在采购原材料`); } make() { console.log(`${this.typeName} 正在制作`); } package() { console.log(`${this.typeName} 正在打包`); } sell() { console.log(`${this.typeName} 正在售卖`); } } class Computer extends API { typeName = '电脑'; procure() { console.log(`${this.typeName} 正在采购原材料`); } make() { console.log(`${this.typeName} 正在制作`); } package() { console.log(`${this.typeName} 正在打包`); } sell() { console.log(`${this.typeName} 正在售卖`); } } // 方式一 // class Factory { // static create(what){ // let obj = null; // eval(` obj = new ${what}();`); // return obj; // } // } // let what = Factory.create('Phone'); // what.sell(); // 方式二 class Factory { static create(what, dowhat){ let obj = null; eval(` obj = new ${what}();`); obj[dowhat](); } } Factory.create('Computer', 'sell');
观察者模式
定义对象间一对多的关系,每当对象发生改变,所有依赖它的对象都会发生相应的改变

// 主体对象Subject(1个) class Subject { constructor() { this.state = 0; this.observer = []; } getState() { return this.state; } setState(state) { this.state = state; this.notifuAllObserver(); } attach(observer) { this.observer.push(observer); this.notifuAllObserver(); } // 广播 notifuAllObserver() { this.observer.forEach(once => { once.update(); }) } } // 观察者Observer class Observer { constructor(name, subject) { this.name = name; this.subject = subject; this.subject.attach(this); } update() { console.log(`this name is ${this.name}, to do update, state value = ${this.subject.state}()`);; } } // 主体对象 let sub = new Subject(); // 观察者 let obj1 = new Observer('张三', sub); let obj2 = new Observer('李四', sub);
适配器模式
适配器用来解决两个已有接口之间不匹配的问题,它并不需要考虑接口是如何实现,也不用考虑将来该如何修改;适配器不需要修改已有接口,就可以使他们协同工作。

class Api { alert(){ throw new Error('该方法不可直接被调用'); } } class Phone extends Api{ alert(){ console.log('手机的alert()方法'); } } class Computer extends Api{ alert(){ console.log('电脑的alert()方法'); } } class Target extends Api{ #targetObj; constructor(className){ super(); eval(`this.targetObj = new ${className}();`); } alert(){ this.targetObj.alert(); } } let obj = new Target('Phone'); obj.targetObj = new Phone(); obj.alert();
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用