小编给大家分享一下javascript观察者模式如何实现自动刷新效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

具体内容如下
// author wangbinandi@gmail.com
const observable = obj => {
const observers = Symbol();
const set = function(target, key, value) {
const result = Reflect.set(target, key, value);
//console.log("set key:" + key);
if ( target[observers].has(key) ) {
target[observers].get(key).forEach(observer => observer());
}
return result;
}
const get = function(target, key) {
const result = Reflect.get(target, key);
//console.log("get key:" + key);
if (arguments.callee.caller) {
if (!target[observers].has(key)) {
target[observers].set(key, new Set())
}
target[observers].get(key).add(arguments.callee.caller);
}
return result;
}
obj[observers] = new Map(); // string => Set()
return new Proxy(obj, {set, get});
};
const autorun = fn => fn();
var person = observable({
firstName: 'Matt',
lastName: 'Ruby',
age: 18,
weight: 50
});
autorun(function () {
console.log('autorun.getAge: ' + person.firstName + ' ' + person.age);
});
autorun(function () {
console.log('autorun.getName: ' + person.firstName + ' ' + person.lastName);
});
person.age = 19;
person.weight = 55;
person.firstName = 'test';
person.lastName = 'MyLast';
console.log(person.lastName);
person.age = 20;以上是“javascript观察者模式如何实现自动刷新效果”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注创新互联成都网站设计公司行业资讯频道!
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。