Observe non-ember globals

限于喜欢 提交于 2020-01-01 02:29:11

问题


I want a computed property to observe a non-ember global: a specific key in localStorage. Is this possible? The following does not seem to cut it:

someProperty:function(){
    //some functionality
}.property('localStorage.someKey')

Is it possible to do what I'm trying to do directly?


回答1:


In general, you can observe regular JavaScript objects just fine. You just need to use Ember.get and Ember.set to modify them:

var pojo = {};

var MyObject = Ember.Object.extend({
  bigEyeballs: function() {
    var O_O = this.get('pojo.O_O');
    if (O_O) { return O_O.toUpperCase(); }
  }.property('pojo.O_O')
});

var obj = MyObject.create({ pojo: pojo });
console.log(obj.get('bigEyeballs'));

Ember.set(pojo, 'O_O', "wat");
console.log(obj.get('bigEyeballs'));

You can see this working in this JSBin.

Local Storage is a bit of a different matter, as it's not really a normal JavaScript object. You can create a small Ember wrapper around local storage, and use that for observation:

var LocalStorage = Ember.Object.extend({
  unknownProperty: function(key) {
    return localStorage[key];
  },

  setUnknownProperty: function(key, value) {
    localStorage[key] = value;
    this.notifyPropertyChange(key);
    return value;
  }
});

var storage = new LocalStorage();

var MyObject = Ember.Object.extend({
  bigEyeballs: function() {
    var O_O = this.get('pojo.O_O');
    if (O_O) { return O_O.toUpperCase(); }
  }.property('pojo.O_O')
});

var obj = MyObject.create({ pojo: storage });

console.log(obj.get('bigEyeballs'));

Ember.set(storage, 'O_O', "wat");
console.log(obj.get('bigEyeballs'));

You can see this live on JSBin.

In both cases, the important thing is that you will have to use Ember-aware setting and getting in order to observe these properties.



来源:https://stackoverflow.com/questions/14290316/observe-non-ember-globals

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!