JS设计模式-状态模式
2022/2/9 6:13:41
本文主要是介绍JS设计模式-状态模式,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
JS设计模式-状态模式
1.原代码
假设我们期望给按钮绑定事件以实现关灯->弱光->强光->关灯的效果
按照一般性思维我们得到了以下代码
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> </head> <body> <button id="button"></button> </body> <script> class Light { constructor(button) { this.button = button; this.currentState = "off"; } initButton() { this.button.onclick = ()=>{ this.pressButton() }; } pressButton() { if (this.currentState === "off") { console.log("弱光"); this.currentState = "weakLight"; } else if (this.currentState === "weakLight") { console.log("强光"); this.currentState = "strongLight"; } else { console.log("无光/关灯"); this.currentState = "off"; } } } let light = new Light(button) light.initButton() </script> </html>
2.原代码存在的问题
1.不符合开放封闭原则
2.胖函数
3.状态切换不明显
4.切换关系不明确
3.采用状态模式进行改进
于是我们便得到了以下代码
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> </head> <body> <button id="button"></button> </body> <script> class Light{ constructor(button){ this.button = button this.offLight = new OffLight(this) this.weakLight = new WeakLight(this) this.strongLight = new StrongLight(this) this.currentStatus = new OffLight(this) } setStatus(newStatus){ this.currentStatus = newStatus } initButton() { this.button.onclick = ()=>{ this.currentStatus.changeState() }; } } class WeakLight{ constructor(light){ this.light = light } changeState(){ console.log('强光'); this.light.setStatus(this.light.strongLight) } } class StrongLight{ constructor(light){ this.light = light } changeState(){ console.log('无光'); this.light.setStatus(this.light.offLight) } } class OffLight{ constructor(light){ this.light = light } changeState(){ console.log('弱光'); this.light.setStatus(this.light.weakLight) } } let light = new Light(button) light.initButton() </script> </html>
*4.采用责任链模式对原代码进行改进
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> </head> <body> <button id="button">switch</button> </body> <script> function chain(fn,status){ this.status = status this.fn = fn this.next = null } function offLight(light){ if(light.status === 'offLight'){ console.log('弱光'); light.status = 'weakLight' }else{ this.next.fn.call(this.next,light) } } function weakLight(light){ if(light.status === 'weakLight'){ console.log('强光'); light.status = 'strongLight' }else{ this.next.fn.call(this.next,light) } } function strongLight(light){ if(light.status === 'strongLight'){ console.log('无光'); light.status = 'offLight' }else{ this.next.fn.call(this.next,light) } } chain.prototype.setNextChain = function(chain){ this.next = chain } chain.prototype.changeStatus = function(){ this.fn() } let light = new chain(function(){this.next.fn.call(this.next,this)},'offLight') let offlight = new chain(offLight,'offLight') let weaklight = new chain(weakLight,'weakLight') let stronglight = new chain(strongLight,'strongLight') light.setNextChain(offlight) offlight.setNextChain(weaklight) weaklight.setNextChain(stronglight) button.onclick = ()=>{ light.changeStatus() } </script> </html>
这篇关于JS设计模式-状态模式的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-04React 19 来了!新的编译器简直太棒了!
- 2025-01-032025年Node.js与PHP大比拼:挑选最适合的后端技术进行现代web开发
- 2025-01-03?? 用 Gemini API、Next.js 和 TailwindCSS 快速搭建 AI 推文生成项目 ??
- 2024-12-31Vue CLI多环境配置学习入门
- 2024-12-31Vue CLI学习入门:一步一步搭建你的第一个Vue项目
- 2024-12-31Vue3公共组件学习入门:从零开始搭建实用组件库
- 2024-12-31Vue3公共组件学习入门教程
- 2024-12-31Vue3学习入门:新手必读教程
- 2024-12-31Vue3学习入门:初学者必备指南
- 2024-12-30Vue CLI多环境配置教程:轻松入门指南