高防服务器

Vue.js怎么实现监听


Vue.js怎么实现监听

发布时间:2022-04-27 11:13:15 来源:高防服务器网 阅读:86 作者:iii 栏目:大数据

这篇“Vue.js怎么实现监听”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Vue.js怎么实现监听”文章吧。

demo:

<script src="../vue.js"> </script>  <div id="app">   <p>   {{ message }}   </p>   <input v-model="message">  </div>  <script type="text/javascript">  new Vue({   el: '#app',   data: {   message: 'Hello Vue.js!'   }  });  </script>          set: function reactiveSetter(newVal) {   var value = getter ? getter.call(obj) : val;   if (newVal === value) {   return;   }   if (setter) {   setter.call(obj, newVal);   } else {   val = newVal;   }   childOb = observe(newVal);   dep.notify();  }

这段代码出现在解析data属性的时候,即调用Object.defineProperty方法配置data的属性。一旦属性发生变化,就notify发送广播。

Dep.prototype.notify = function () {   // stablize the subscriber list first   var subs = toArray(this.subs);   for (var i = 0, l = subs.length; i < l; i++) {   subs[i].update();   }  };

notify 最终是周知subscribe(订阅者)更新,那么上面的数据变更就是发布者。 subscribe是Watcher这个类的实例化对象,在实例化的时候,会传入回调函数来执行update,vue弄了一个队列来执行watcher的更新函数,具体可参考源码。

Watcher.prototype.run = function () {   ……   if (value !== this.value || (isObject(value) || this.deep) && !this.shallow) {   ……   } else {   this.cb.call(this.vm, value, oldValue);   }   }   this.queued = this.shallow = false;   }   };

在Directive(指令)class中实例化了Watcher,_update函数负责来更新

var watcher = this._watcher = new Watcher(this.vm, this.expression, this._update, // callback   {   filters: this.filters,   twoWay: this.twoWay,   deep: this.deep,   preProcess: preProcess,   postProcess: postProcess,   scope: this._scope   });

在解析模板的时候会解析Directive,然后绑定,实例化watcher,这样模板-data就关联在一起了。

图片描述

观察者模式

林林总总的mvc或者mvvm框架基本也都是利用了观察者模式,这个也非常有用,尤其在复杂的系统之中。

利用观察者模式,在典型的ajax应用中,回调的处理逻辑可以不跟请求耦合在一块,这样逻辑上也会更加清晰。如下是一个简单的发布/订阅模式的实现

var PubSub = {};  (function (q) {   var topics = {}, subUid = -1;   q.publish = function (topic) {   if(!topics[topic]){    return false;   }     var subscribers = topics[topic],    len = subscribers ? subscribers.length : 0;     while(len--){    var args = Array.prototype.slice.call(arguments, 1);    args.unshift(topic);    subscribers[len].callback.apply(this, args);   }   return this;   };     q.subscribe = function (topic, callback) {   if(!topics[topic]){    topics[topic] = [];   }     var subuid = (++subUid).toString();     topics[topic].push({    token: subuid,    callback: callback   });     return subuid;   };     q.unsubscribe = function (subid) {   for(var k in topics){    if(topics[k]){    for(var i = 0, j = topics[k].length; i < j; i++){     if(topics[k][i].token === subid){     topics[k].splice(i, 1);     return subid;     }    }    }   }   return this;   };  })(PubSub);

这就是一个简单的订阅发布系统,每注册一个订阅者,其实就是将其回调处理的callback保存在一个字典对象的数组中,字典对象的key值可以随意定义,只要与发布时的key对应起来就好。

怎么使用呢?

<script>  var messageLogger = function(){   console.log(JSON.stringify(arguments));   };    var subscription = PubSub.subscribe('/newMessage', messageLogger);  // {"0":"/newMessage","1":"hello world"}  PubSub.publish('/newMessage', 'hello world');    // {"0":"/newMessage","1":["test","a","b","c"]}  PubSub.publish('/newMessage', ['test', 'a', 'b', 'c']);    // {"0":"/newMessage","1":{"sender":"hello world","body":"hey man"}}  PubSub.publish('/newMessage', {   sender: 'hello world',   body: 'hey man'  });    PubSub.unsubscribe(subscription);    PubSub.publish('/newMessage', ['test', 'a', 'b', 'c'], 1);  </script>

最后一个将不会打印出来,因为已经取消订阅了。

以上就是关于“Vue.js怎么实现监听”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注高防服务器网行业资讯频道。

[微信提示:高防服务器能助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。

[图文来源于网络,不代表本站立场,如有侵权,请联系高防服务器网删除]
[