加入收藏 | 设为首页 | 会员中心 | 我要投稿 晋中站长网 (https://www.0354zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

JavaScript 的一些常用设计模式

发布时间:2019-08-20 11:28:13 所属栏目:优化 来源:xianshannan
导读:设计模式是前人解决某个特定场景下对而总结出来的一些解决方案。可能刚开始接触编程还没有什么经验的时候,会感觉设计模式没那么好理解,这个也很正常。有些简单的设计模式我们有时候用到,不过没意识到也是存在的。 学习设计模式,可以让我们在处理问题的

假设我们的绩效分为 A、B、C、D 这四个等级,四个等级的奖励是不一样的,一般我们的代码是这样实现:

  1. /** 
  2.  
  3. * 获取年终奖 
  4.  
  5. * @param {String} performanceType 绩效类型, 
  6.  
  7. * @return {Object} 年终奖,包括奖金和奖品 
  8.  
  9. */ 
  10.  
  11. function getYearEndBonus(performanceType) { 
  12.  
  13. const yearEndBonus = { 
  14.  
  15. // 奖金 
  16.  
  17. bonus: '', 
  18.  
  19. // 奖品 
  20.  
  21. prize: '', 
  22.  
  23.  
  24. switch (performanceType) { 
  25.  
  26. case 'A': { 
  27.  
  28. yearEndBonus = { 
  29.  
  30. bonus: 50000, 
  31.  
  32. prize: 'mac pro', 
  33.  
  34.  
  35. break 
  36.  
  37.  
  38. case 'B': { 
  39.  
  40. yearEndBonus = { 
  41.  
  42. bonus: 40000, 
  43.  
  44. prize: 'mac air', 
  45.  
  46.  
  47. break 
  48.  
  49.  
  50. case 'C': { 
  51.  
  52. yearEndBonus = { 
  53.  
  54. bonus: 20000, 
  55.  
  56. prize: 'iphone xr', 
  57.  
  58.  
  59. break 
  60.  
  61.  
  62. case 'D': { 
  63.  
  64. yearEndBonus = { 
  65.  
  66. bonus: 5000, 
  67.  
  68. prize: 'ipad mini', 
  69.  
  70.  
  71. break 
  72.  
  73.  
  74.  
  75. return yearEndBonus 
  76.  

使用策略模式可以这样:

  1. /** 
  2.  * 获取年终奖 
  3.  * @param {String} strategyFn 绩效策略函数 
  4.  * @return {Object} 年终奖,包括奖金和奖品 
  5.  */ 
  6. function getYearEndBonus(strategyFn) { 
  7.   if (!strategyFn) { 
  8.     return {} 
  9.   } 
  10.   return strategyFn() 
  11.  
  12. const bonusStrategy = { 
  13.   A() { 
  14.     return { 
  15.       bonus: 50000, 
  16.       prize: 'mac pro', 
  17.     } 
  18.   }, 
  19.   B() { 
  20.     return { 
  21.       bonus: 40000, 
  22.       prize: 'mac air', 
  23.     } 
  24.   }, 
  25.   C() { 
  26.     return { 
  27.       bonus: 20000, 
  28.       prize: 'iphone xr', 
  29.     } 
  30.   }, 
  31.   D() { 
  32.     return { 
  33.       bonus: 10000, 
  34.       prize: 'ipad mini', 
  35.     } 
  36.   }, 
  37.  
  38. const performanceLevel = 'A' 
  39. getYearEndBonus(bonusStrategy[performanceLevel]) 

这里每个函数就是一个策略,修改一个其中一个策略,并不会影响其他的策略,都可以单独使用。当然这只是个简单的范例,只为了说明。

策略模式比较明显的特性就是可以减少 if 语句或者 switch 语句。

职责链模式

顾名思义,责任链模式(Chain of Responsibility Pattern)为请求创建了一个接收者对象的链。这种模式给予请求的类型,对请求的发送者和接收者进行解耦。这种类型的设计模式属于行为型模式。

在这种模式中,通常每个接收者都包含对另一个接收者的引用。如果一个对象不能处理该请求,那么它会把相同的请求传给下一个接收者,依此类推。

(编辑:晋中站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

热点阅读