EmberJS - Modello di segmenti multipli

Per più segmenti, puoi fornire un modello o un identificatore per ogni segmento se il percorso è nidificato.

Sintassi

Router.map(function() {
   this.resource('route_name');
   this.resource('route_name', { path: 'route_path' });
});

Esempio

L'esempio mostra l'utilizzo di più segmenti nel percorso annidato fornendo un identificatore al segmento. Crea due percorsi con i nomi come informazioni e registra e apri il file router.js per definire i mapping degli URL -

import Ember from 'ember';
import config from './config/environment';

const Router = Ember.Router.extend ({
   location: config.locationType,
   rootURL: config.rootURL
});

Router.map(function() {
   this.route('info');
   this.route('record', { path: 'records/:records_id' });
});

export default Router;

Apri il file application.hbs file creato in app / templates / con il seguente codice:

{{#link-to 'info'}}Fruits{{/link-to}}
{{#link-to 'record' recoModel}}Some Record{{/link-to}}
{{outlet}}

Quando fai clic sul link "Fruits", la pagina dovrebbe aprire il file info.hbs , che contiene il seguente codice:

<p>Some Fruits</p>
<ul>
   <li>Orange</li>
   <li>Banana</li>
</ul>
{{outlet}}

Se fai clic sul collegamento Some Record , la pagina dovrebbe aprire il file record.hbs , che contiene il codice seguente:

<p>Some Records</p>
{{model.name}}
{{outlet}}

Ora crea il controller application.js , che verrà creato in app / controller / to con il seguente codice:

import Ember from 'ember';

export default Ember.Controller.extend ({
   recoModel: function(){
      //return the records value to the called route
      return {records_id:1, name:'Docs List'};
   }.property()
});

Produzione

Esegui il server ember; riceverai il seguente output -

Quando fai clic sul collegamento Fruits , verrà visualizzato il seguente testo dal file modello:

Quando fai clic sul collegamento Some Record , verrà visualizzato il testo seguente dal file modello: