Javascript 聚合物,观察全局变量
我有多个自定义元素,它们共享相同的数据列表。 我试图在全局列表更改时触发事件 下面的代码适用于FF和Safari,但不适用于Chrome。 有没有关于这个问题的建议,或者更好的方法 谢谢Javascript 聚合物,观察全局变量,javascript,variables,global,polymer,observers,Javascript,Variables,Global,Polymer,Observers,我有多个自定义元素,它们共享相同的数据列表。 我试图在全局列表更改时触发事件 下面的代码适用于FF和Safari,但不适用于Chrome。 有没有关于这个问题的建议,或者更好的方法 谢谢 (function() { var _list = null; Polymer("dmw-datatypes", { ready:function(){ ...retreiving a list async...
(function() {
var _list = null;
Polymer("dmw-datatypes", {
ready:function(){
...retreiving a list async...
},
get list() {
return _list;
},
listReceived: function(json) {
_list=json;
},
listChanged: function(oldValue, newValue) {
this.fire('list-received');
}
});
})();
这听起来像是
Object.observe()
(在Chrome中是原生的)带有计算属性(比如您的get list(){}
)的症状。其他浏览器使用手动脏检查来填充此行为,因此工作正常。基本上,您需要创建自己的Object.observe()通知程序
并在您使用通知程序.notify()更新列表时通知观察者。上面的链接给出了一个例子
var notifier = Object.getNotifier(this);