js设计模式-观察者模式来模拟vue的双向数据绑定

JavaScript019

js设计模式-观察者模式来模拟vue的双向数据绑定,第1张

vue的双向数据绑定大家应该很熟悉了,当一方的值发生改变时,另一方绑定的值也会随之变化,用起来是挺嗨的。

但是在原生中我们怎么使用这种机制呢?

最近有个需求是通过对接websocket获取后台服务器实时变化的值,推送给web端使用。

基于这个需求,我使用到了js中的设计模式-观察者模式。

那么,让我们来一起了解一下吧。

先来看看具体机制:

这里对象定义了四个属性,分别绑定四个函数。

1、订阅:订阅方通过传递回调函数,观察者模式把这个回调函数push到自身的订阅功能里,以此来得知谁订阅了,然后判断是否要推送。

2、退订:找到对应的回调函数,然后在自身的订阅功能里把当前函数删除掉

3、发布:循环所有的订阅方,当发布方进行发送的时候,把对应的数据推送给订阅方

4、发布订阅:定义一个对象,使其具备订阅并且发布的功能

流程是这样,说起来头头是道的,问题是怎么使用?

举个栗子:

我想定义一个对象,使其具备发布订阅功能,发布方数值改变的时候,订阅方得到平方值得变化

这里通过input框的change事件,模拟了数据的实时变更,然后把当前值进行发布,这边一发布,订阅方就能通过回调函数得到实时变化的值,然后得到值进行相应的操作。

效果:

这样就能简单实现数据变更推送功能了。

注:文件中引入的observer的js是最上面提到的观察者模式的那一套流程,tools的js大家可以不必在意,是我自己原生封装的$函数,用来获取dom元素的。

具体需求,大家还需要变通,稍作修改。

好了,以上就是js的观察者模式实现的双向数据绑定。

如有问题,请指出,接受批评。

该接口用来观察节点变化,MutationObserver是一个构造器,接收一个回调函数callback用来处理节点变化时所做的操作。 var observe = new MutationObserver(mutationCallback)     var observe = new MutationObserver(mutationCallback)      observe.observe(dom, config)// 后面介绍config的配置    var observe = new MutationObserver(mutationCallback)    observe.disconnect()     var observe = new MutationObserver(mutationCallback)     var record = observe.takeRecords() let config = {     attributes: true, //目标节点的属性变化     childList: true, //目标节点的子节点的新增和删除     characterData: true, //如果目标节点为characterData节点(一种抽象接口,具体可以为文本节点,注释节点,以及处理指令节点)时,也要观察该节点的文本内容是否发生变化     subtree: true, //目标节点所有后代节点的attributes、childList、characterData变化 }  <div id="h">123123</div>     <script>             window.onload=function(){                 // Firefox和Chrome早期版本中带有前缀                 var MutationObserver = window.MutationObserver || window.WebKitMutationObserver || window.MozMutationObserver                 // 选择目标节点                 var target = document.querySelector('#h')                  // 创建观察者对象                 var observer = new MutationObserver(function(mutations) {                       mutations.forEach(function(mutation) {                          console.log(mutation)                      })                  })                  // 配置观察选项:                 var config = { attributes: true, childList: true, characterData: true }                  // 传入目标节点和观察选项                 observer.observe(target, config)                  // 随后,你还可以停止观察                 // observer.disconnect()                 document.getElementById('h').onclick=function(){                 // this.style.width="50px"                 this.innerHTML = "888888"                 }             }     </script> 原文链接:https://blog.csdn.net/weixin_42420703/article/details/98334813