设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

JavaScript 的一些常用设计模式(5)

发布时间:2019-08-19 17:07 所属栏目:21 来源:xianshannan
导读:假设我们的绩效分为 A、B、C、D 这四个等级,四个等级的奖励是不一样的,一般我们的代码是这样实现: /** *获取年终奖 *@param{String}performanceType绩效类型, *@return{Object}年终奖,包括奖金和奖品 */ funct

假设我们的绩效分为 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)为请求创建了一个接收者对象的链。这种模式给予请求的类型,对请求的发送者和接收者进行解耦。这种类型的设计模式属于行为型模式。

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

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读