如何用状态模式优化你的 JavaScript 代码

网站建设3年前发布
18 0 0

状态模式是一个有趣的模式,它可能是解决一些需求场景的最佳方式。虽然状态模式不是一种易于学习的模式(它通常会导致代码量增加),但一旦您了解了状态模式的本质,您将在未来感谢它无与伦比的好处。,网上很多文章在解释状态模式时,都过于理论化,难以理解。这里我尝试用一个实际案例用通俗易懂的方式来解释。,2023030601523002ab49c166ab0ee0daf812b6bbb2e23857ffcb595,让我们想象一个场景,其中有一盏灯只有一个开关。,202303060152310509d411503f23ed3b4383193eae0af28d5d9b142,我们可以发现一个特点:同一个开关按钮在不同的状态下会有不同的行为。,现在让我们编写一段代码来模拟灯光,并打开和关闭灯光,如何编写代码?,一个简单的实现:,2023030601523138cde1d928db409158a14285f20072b3e2e836542,用法:,2023030601523167745ea603d2503d1cc045c7055cc96f255c54938,在上面的场景中,灯只有两种状态,所以代码写起来比较简单。,但我们需要知道,在现实生活中,很多物体都有两种以上的状态,一旦一个对象有更多的状态,它就会更麻烦。,例如,有些手电筒具有三种状态:,第一次按下开关打开弱光,第二次按下打开强光,第三次按下关闭灯。,20230306095652b956768882f96de4704590b5cb28c940d10afb226,现在让我们模拟这样的行为,我们应该如何写代码?,正常的解决方案是扩展前面的代码,在clickButton方法中进行一些额外的状态判断和状态切换。,
,20230306015234718c97b96bf4a557b14927788aea4c636df104542,
,虽然这样的代码可以满足要求,但它有很多缺点。,20230306015234f3bb81d6869dca1bb428820efb6af1533b7ea8295,让我们回想一下,我们的代码使用 Light 作为一个单独的对象,然后它具有三种状态。然后我们需要让它在不同的状态之间切换,我们将不同的状态视为光的内部属性。,但实际上,我们可以打破惯性思维,将每一个状态都视为一个独立的存在,封装成一个单独的类。,比如这里的灯有三种状态:,不同状态的灯有自己的行为特征。,LowLightState 的clickButton 方法将状态切换为StrongLightState,StrongLightState 的clickButton 将状态切换为OffState。,20230306095528415c20a31f75d50442f06537d83476519e15e5271,而我们的Light只需要关注它处于什么状态,不需要处理状态切换,状态切换由每个状态自己处理。,这是完整的代码:,图中解释:,2023030601523486a1dab5916bd09a42844008fc4e379725899e984,这样的代码可以解决前面提到的问题:,轻物体更简单。它只需要调用this.currentState.clickButton(),状态切换可以由状态对象自己处理。,如果将来有新的状态,我们只需要创建一个新的状态类,然后修改其相邻的状态类,而不需要对现有代码进行大量修改。,2023030601523544739a1122a28a12b735386a33452ddb028a6e929,这种编写代码的技术就是状态模式。,状态模式的正式定义:,状态模式是一种行为软件设计模式,它允许对象在其内部状态发生变化时改变其行为。这种模式接近于有限状态机的概念。状态模式可以解释为策略模式,它能够通过调用模式接口中定义的方法来切换策略。​,简单来说,如果你的对象有多个状态,并且不同状态的对象表现不同,那么你可以考虑使用状态模式。,状态模式有时会增加代码行数,但代码的质量并不取决于代码行数。使用状态模式通常可以使您的对象的逻辑更加简洁。,以上就是我今天与你分享的关于在JavaScript中使用状态模式简化对象的全部内容,希望这些内容对你有帮助,如果你觉得我今天的内容有用的话,请将它分享给你身边的朋友,也许能够帮助到他。

© 版权声明

相关文章