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

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

发布时间:2019-08-19 17:07 所属栏目:21 来源:xianshannan
导读:然后加上目标和观察者 classSubject{ constructor(){ this.observers=[] } add(observer){ this.observers.push(observer) } notify(data){ this.observers.forEach((observer)=observer.update(data)) } } classOb

然后加上目标和观察者

  1. class Subject { 
  2.   constructor() { 
  3.     this.observers = [] 
  4.   } 
  5.  
  6.   add(observer) { 
  7.     this.observers.push(observer) 
  8.   } 
  9.  
  10.   notify(data) { 
  11.     this.observers.forEach((observer) => observer.update(data)) 
  12.   } 
  13.  
  14. class Observer { 
  15.   constructor(callback) { 
  16.     this.callback = callback 
  17.   } 
  18.   update(data) { 
  19.     this.callback && this.callback(data) 
  20.   } 
  21.  
  22. // 创建观察者ob1 
  23. let ob1 = new Observer((text) => { 
  24.   document.querySelector('#dom-one').innerHTML(text) 
  25. }) 
  26. // 创建观察者ob2 
  27. let ob2 = new Observer((text) => { 
  28.   document.querySelector('#dom-two').innerHTML(text) 
  29. }) 
  30. // 创建目标sub 
  31. let sub = new Subject() 
  32. // 目标sub添加观察者ob1 (目标和观察者建立了依赖关系) 
  33. sub.add(ob1) 
  34. // 目标sub添加观察者ob2 
  35. sub.add(ob2) 
  36. // 目标sub触发事件(目标主动通知观察者) 
  37. sub.notify('这里改变了') 

组合在一起是这样的

  1. <!DOCTYPE html> 
  2. <html> 
  3.   <head> 
  4.     <meta charset="utf-8" /> 
  5.     <meta 
  6.       name="viewport" 
  7.       content="width=device-width,initial-scale=1,maximum-scale=1,viewport-fit=cover" 
  8.     /> 
  9.     <title></title> 
  10.   </head> 
  11.   <body> 
  12.     <div id="app"> 
  13.       <div id="dom-one"> 
  14.         原来的值 
  15.       </div> 
  16.       <br /> 
  17.       <div id="dom-two"> 
  18.         原来的值 
  19.       </div> 
  20.       <br /> 
  21.       <button id="btn">改变</button> 
  22.     </div> 
  23.     <script> 
  24.       class Subject { 
  25.         constructor() { 
  26.           this.observers = [] 
  27.         } 
  28.  
  29.         add(observer) { 
  30.           this.observers.push(observer) 
  31.         } 
  32.  
  33.         notify() { 
  34.           this.observers.forEach((observer) => observer.update()) 
  35.         } 
  36.       } 
  37.  
  38.       class Observer { 
  39.         constructor(callback) { 
  40.           this.callback = callback 
  41.         } 
  42.         update() { 
  43.           this.callback && this.callback() 
  44.         } 
  45.       } 
  46.  
  47.       const obj = { 
  48.         data: { description: '' }, 
  49.       } 
  50.  
  51.       // 创建观察者ob1 
  52.       const ob1 = new Observer(() => { 
  53.         console.log(document.querySelector('#dom-one')) 
  54.         document.querySelector('#dom-one').innerHTML = obj.description 
  55.       }) 
  56.       // 创建观察者ob2 
  57.       const ob2 = new Observer(() => { 
  58.         document.querySelector('#dom-two').innerHTML = obj.description 
  59.       }) 
  60.       // 创建目标sub 
  61.       const sub = new Subject() 
  62.       // 目标sub添加观察者ob1 (目标和观察者建立了依赖关系) 
  63.       sub.add(ob1) 
  64.       // 目标sub添加观察者ob2 
  65.       sub.add(ob2) 
  66.  
  67.       Object.defineProperty(obj, 'description', { 
  68.         get() { 
  69.           return this.data.description 
  70.         }, 
  71.         set(val) { 
  72.           this.data.description = val 
  73.           // 目标sub触发事件(目标主动通知观察者) 
  74.           sub.notify() 
  75.         }, 
  76.       }) 
  77.       btn.onclick = () => { 
  78.         obj.description = '改变了' 
  79.       } 
  80.     </script> 
  81.   </body> 
  82. </html> 

装饰者模式

装饰器模式(Decorator Pattern)允许向一个现有的对象添加新的功能,同时又不改变其结构。

ES6/7 的decorator 语法提案,就是装饰者模式。

(编辑:ASP站长网)

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