介绍一个款可以在javascript对象上实现观察者模式的类库-Watch.js

 

最近发现一个比较有意思的js库可以为javascript的对象实现观察者模式,以往我们使用javascript实现的观察者模式都是通过使用回调函数配合dom上的event事件来操作的,而“Watch.js”可以为javascript的对象实现观察者模式,监听对象的变化。

 

 watch.js目前主要可以做如下这些事情:

 1,监听对象上一个或多个属性的改变,当改变后触发自定义事件。

 2,批量观察一个对象上所有的属性,当有任何一个改变时,触发自定义事件。

 3,可以取消订阅观察

 4,你可以在你需要的时候,不用改变对象上的属性值,就可手动触发观察器。

 5,可以与jquery兼容 

 

下面看一个watch.js的基本使用,更多的代码可以参考本文最后的项目地址。

  

var ex1 = {
    attr1: "initial value of attr1",
    attr2: "initial value of attr2"
};

//监听ex1的attr1,当attr1值发送改变时候触发函数
watch(ex1, "attr1",  function(){
    alert("attr1 changed!");
});
//改变attr1值将弹出 attr1 changed!
ex1.attr1 = "other value";  

该类库内部由于目前是使用__defineSetter__与__defineGetter__实现,所以目前只能工作在如下浏览器中。

* IE 9+, FF 4+, SF 5+, WebKit, CH 7+, OP 12+, BESEN, Rhino 1.7+

不过开发者声称在一下次的更新中将会兼容所有浏览器(我还没想明白在IE8以前如何实现,有高人可以指点一下)。有兴趣的朋友也可以在github关注这个项目。

 

 项目地址:https://github.com/melanke/Watch.JS  
 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值