EmberJS - Gestione del completamento dell'azione e del passaggio di argomenti

Il componente può gestire il completamento dell'azione restituendo una promessa e gli argomenti possono essere passati a un componente utilizzando un helper di azione.

Sintassi

L'azione può essere implementata come:

import Ember from 'ember';

export default Ember.Component.extend ({
   actions: {
      action_name() {
         //code here
      }
   }
});

Gli argomenti possono essere passati a un componente come:

{{component_name text = "text-here" action-helper = (action "action_name" "args")}}

Esempio

L'esempio riportato di seguito specifica la gestione del completamento dell'azione e il passaggio di argomenti nell'applicazione. Crea un componente con il nome ember-actions e apri il file modello del componente ember-actions.js creato in app / components / con il seguente codice:

import Ember from 'ember';

export default Ember.Component.extend ({
   doubleClick: function() {
      this.toggleProperty('isEditing');
   },
   isEditing: false

});

Apri il file ember-actions.hbs creato in app / templates / components / e inserisci il seguente codice:

{{#if isEditing}}
   <p>Title: {{input value = title}}</p>
   <p>url: {{input value = url}}</p>
   <p>Double click on the save button to save information.</p>
   <button>Save</button>
{{else}}
   <p>Double click on the form to enter details:</p>
   <p>Title: {{title}}</p>  
   <p>url: {{url}}</p>
{{/if}}
{{yield}}

Crea il file application.hbs e aggiungi il codice seguente:

{{ember-actions}}
{{outlet}}

Produzione

Esegui il server ember; riceverai il seguente output -

Dopo aver fatto doppio clic sul modulo, visualizzerà il modulo e inserirà i dettagli in esso. Quindi fare doppio clic sul pulsante Salva per salvare i dettagli -

Ora vedrai i dettagli salvati come mostrato nello screenshot qui sotto -