Ember.js 观察非余烬球

Ember.js 观察非余烬球,ember.js,Ember.js,我想要一个计算属性来观察非余烬全局:localStorage中的特定键。这可能吗?以下几点似乎无法解决这一问题: someProperty:function(){ //some functionality }.property('localStorage.someKey') 是否可以直接执行我试图执行的操作?通常,您可以很好地观察常规JavaScript对象。您只需要使用Ember.get和Ember.set来修改它们: var pojo = {}; var MyObject = E

我想要一个计算属性来观察非余烬全局:localStorage中的特定键。这可能吗?以下几点似乎无法解决这一问题:

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

是否可以直接执行我试图执行的操作?

通常,您可以很好地观察常规JavaScript对象。您只需要使用
Ember.get
Ember.set
来修改它们:

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'));
你可以看到它在工作

本地存储有点不同,因为它不是真正的普通JavaScript对象。您可以在本地存储周围创建一个小的余烬包装,并将其用于观察:

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'));
你可以在现场看到这个

在这两种情况下,重要的是您必须使用余烬感知设置和获取来观察这些属性