我写了一个加载通知的服务:
import Ember from 'ember';
export default Ember.Service.extend({
sessionUser: Ember.inject.service(),
store: Ember.inject.service(),
read() {
let currentUserId = this.get('sessionUser.user.id');
return this.get('store').query('notification', {
userId: currentUserId,
read: true
});
},
unread() {
let currentUserId = this.get('sessionUser.user.id');
return this.get('store').query('notification', {
userId: currentUserId,
read: false
});
}
});
我想在有未读通知时更改导航栏中图标的颜色。导航栏是一个组件:
import Ember from 'ember';
export default Ember.Component.extend({
notifications: Ember.inject.service(),
session: Ember.inject.service(),
hasUnreadNotifications: Ember.computed('notifications', function() {
return this.get('notifications').unread().then((unread) => {
return unread.get('length') > 0;
});
})
});
然后模板使用hasUnreadNotifications
属性来决定是否应该使用高亮类:
<span class="icon">
<i class="fa fa-bell {{if hasUnreadNotifications 'has-notifications'}}"></i>
</span>
然而,它不起作用。虽然调用了存储并返回了通知,但hadUnreadNotifications
并未解析为布尔值。我认为这是因为它返回了一个承诺而模板无法处理,但我不确定。
问题
hasUnreadNotifications
没有返回布尔值?read
和unread
属性而不是函数,因此可以在服务中创建计算属性来计算计数?答案 0 :(得分:2)
从计算属性返回承诺将不起作用。计算属性不是Promise意识。要使它工作,您需要返回DS.PrmoiseObject或DS.PromiseArray。
您可以阅读此igniter article中提供的其他选项。
import Ember from 'ember';
import DS from 'ember-data';
export default Ember.Component.extend({
notifications: Ember.inject.service(),
session: Ember.inject.service(),
hasUnreadNotifications: Ember.computed('notifications', function() {
return DS.PromiseObject.create({
promise: this.get('notifications').unread().then((unread) => {
return unread.get('length') > 0;
})
});
})
});