Molto spesso capita di dover creare pulsanti con un HTML complesso per dare la possibilità di aggiungere icone a destra o sinistra del test, per dare uniformità di stile o per aggiungere determinati comportamenti. Per evitare di scrivere codice HTML duplicato per ogni pulsante, possiamo creare un component che al suo interno include tutto il codice HTML e di logica necessario al corretto funzionamento del pulsante.
Il nostro component deve esporre un evento che corrisponde al click del pulsante interno. Se chiamiamo l'evento click, Angular eseguirà l'evento due volte, una per il pulsante e una per il tag che viene renderizzato in HTML per il component.
<!--component-->
<button class="btn btn-primary btn-sm" (click)="bubbleClick($event)">
<i [class]="iconFirst" *ngIf="iconFirst"></i>
<ng-content></ng-content>
<i [class]="iconLast" *ngIf="iconLast"></i>
</button>import { Component, OnInit, Input, EventEmitter, Output } from '@angular/core';
@Component({
selector: 'app-button',
templateUrl: './button.component.html'
})
export class ButtonComponent implements OnInit {
@Output() click = new EventEmitter();
bubbleClick(event: Event) {
this.click.emit();
}
}Come detto, in questo caso l'HTML dichiara un evento click per il pulsante dentro il component, e ne dichiarerà un altro per il tag che contiene il component (
bubbleClick(event: Event) {
event.stopPropagation();
this.click.emit();
}Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Gestire codice JavaScript con code splitting e lazy loading
Ricerca delle GitHub issue tramite operatori logici
Analizzare il contenuto di una issue con GitHub Models e AI
Proteggere l'endpoint dell'agente A2A delle Logic App
Creare un agente A2Acon Azure Logic Apps
Gestire progetti NPM in .NET Aspire
Conoscere il rendering Server o WebAssembly a runtime in Blazor
Effettuare un clone parziale di un repository di GitHub
Supportare la sessione affinity di Azure App Service con Application Gateway
Mappare una complex property di una entity su un campo JSON
Utilizzare Locust con Azure Load Testing
Gestire trasferimenti cloud con Azure Storage Mover
I più letti di oggi
- Effettuare il multi-checkout in linea nelle pipeline di Azure DevOps
- Esaminare documenti XML con namespace utilizzando LINQ to XML
- Alleggerire le applicazioni WPF sfruttando gli oggetti Freezable
- Le DirectInk API nella Universal Windows Platform
- Sfruttare una CDN con i bundle di ASP.NET
- Effetto turnstile su tutte le pagine con il Windows Phone Toolkit
- Gli oggetti CallOut di Expression Blend 4.0


