我想要一个计算属性来观察非余烬全局:localStorage 中的特定键。这可能吗?以下似乎并没有削减它:
someProperty:function(){
//some functionality
}.property('localStorage.someKey')
是否可以直接做我想做的事情?
我想要一个计算属性来观察非余烬全局: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'));
你可以在这个 JSBin中看到这个工作。
本地存储有点不同,因为它不是一个真正的普通 JavaScript 对象。您可以围绕本地存储创建一个小型 Ember 包装器,并将其用于观察:
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'));
你可以在JSBin上看到这一点。
在这两种情况下,重要的是您必须使用 Ember 感知设置和获取来观察这些属性。