Différences
Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentes Révision précédente Prochaine révision | Révision précédente | ||
richclient:emberjs:router:models [2018/01/18 15:45] – [Models dynamiques] jcheron | richclient:emberjs:router:models [2019/08/31 14:21] (Version actuelle) – modification externe 127.0.0.1 | ||
---|---|---|---|
Ligne 69: | Ligne 69: | ||
</ | </ | ||
- | ===== Paramètres hérités ===== | ||
- | Il arrive qu'une route ne possède pas le paramètre d'url dont elle aurait besoin, en particulier s'il s'agit d'une route enfant. | + | ===== Models multiples ===== |
+ | Dans certains cas, la route peut avoir besoin de plusieurs models. | ||
+ | Ember utilise dans ce cas la méthode hash du package RSVP permettant de définir une seule **promise** à partir de plusieurs **promises** existantes : | ||
+ | <sxh javascript; | ||
+ | import Route from '@ember/ | ||
+ | import RSVP from 'rsvp'; | ||
+ | export default Route.extend({ | ||
+ | model() { | ||
+ | return RSVP.hash({ | ||
+ | songs: this.get(' | ||
+ | albums: this.get(' | ||
+ | }); | ||
+ | } | ||
+ | }); | ||
+ | </ | ||
+ | ===== Contexte parent ===== | ||
+ | Il arrive qu'une route ne possède pas les paramètres d'url dont elle aurait besoin, en particulier s'il s'agit d'une route enfant. | ||
+ | |||
+ | Il est possible dans ce cas d' | ||
+ | |||
+ | Dans le cas suivant, la route **album/ | ||
+ | <sxh javascript; | ||
+ | import Route from ' | ||
+ | |||
+ | export default Route.extend({ | ||
+ | model() { | ||
+ | let { album_id } = this.paramsFor(' | ||
+ | |||
+ | return this.store.query(' | ||
+ | } | ||
+ | }); | ||
+ | </ | ||
+ | |||
+ | |||
+ | Il est également possible de récupérer le model délivré par une route parent avec la méthode **modelFor** : | ||
+ | <sxh javascript; | ||
+ | import Route from ' | ||
+ | |||
+ | export default Route.extend({ | ||
+ | model() { | ||
+ | let { songs } = this.modelFor(' | ||
+ | |||
+ | return songs; | ||
+ | } | ||
+ | }); | ||
+ | </ |