Implementazione dell'azione e progettazione del componente figlio

È possibile implementare l'azione sul componente padre chiamando il metodo di azione specificato e creare una logica nel componente figlio per il metodo di azione specificato.

Sintassi

L'azione può essere implementata come indicato di seguito:

import Ember from 'ember';

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

Il componente figlio può essere implementato come nella seguente riga di codice:

<tag_name {{action "action_name"}}>{{Text Here}}</end_of_tag>

Esempio

L'esempio riportato di seguito specifica l'implementazione dell'azione e la progettazione del componente figlio 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 ({
   actions: {
      toggleBody() {
         this.decrementProperty('isShowingBody');
      },
      cancelBody() {
         this.incrementProperty('isShowingBody');
      }
   }
});

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

<button {{action "toggleBody"}}>{{title}}Show (Display Text)</button>
{{#if isShowingBody }}
   <h2>Welcome to Tutorialspoint...</h2>
{{/if}}
<button class="confirm-cancel" {{action "cancelBody"}}>{{title}}Hide (Hides Text)
</button>
{{yield}}

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

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

Produzione

Esegui il server ember; riceverai il seguente output -

Quando fai clic sul pulsante "Mostra", verrà visualizzato il testo e il testo verrà nascosto facendo clic sul pulsante "Nascondi" -