Hello!
I have a trouble with accesing relation on model passed to component/
Model example:
name: DS.attr('string'),
rel: belongsTo('something')
component calling:
{{cp m=model}}
component template (here all fine, i see relation visible property value):
{{m.rel.visible}}
component.js (here returnerd value is undefined, why?)
export default Ember.Component.extend({
isVisible: Ember.computed(function(){
return this.get('m').get('rel').get('visible');
}),
}
P.S. Cannot format code…
You need to let Ember know what properties your computed property depends on, also you don’t need to use get so many times. This should work:
isVisible: Ember.computed(‘m.rel.visible’, function(){
return this.get(‘m.rel.visible’);
})
Better yet, you can just use alias since that’s all you are effectively doing data:image/s3,"s3://crabby-images/fc6d2/fc6d27ad610fa159f2466a504b7cfca7fb8c9b8f" alt=":slight_smile: :slight_smile:"
isVisible: Ember.computed.alias(‘m.rel.visible’)
1 Like
All working! Nice solution, can i inject all properties of m.rel or 2-3 only?
Maybe something ‘m.rel.$each’ ?
Depends on your use-case, typically you would want to use a normal computed property when you need some additional logic or manipulation. If all you want is to access the value then alias is a better fit.
This is a good read that might explain it a bit more - Computed Properties and Aggregate Data - The Object Model - Ember Guides