Negli script precedenti abbiamo analizzato le direttive built-in più usate in AngularJS. Sebene queste direttive coprano le esigenze più comuni, a volte non sono sufficienti a coprire scenari più complessi necessari per la nostra applicazione. In questi casi dobbiamo ricorrere alla creazione di una direttiva custom.
Creare una direttiva custom con AngularJS può essere estremamente semplice o estremamente complicato a seconda di quello che si deve fare. In questo esempio vedremo come creare una direttiva che mostra un semplice tag HTML.
var app = angular.module("myApp", []); app.directive("My-Directive", function() { return { template : "<h1>Direttiva</h1>" }; });
Il primo passo consiste nel creare il modulo per poi creare al suo interno la direttiva. La direttiva si crea con il metodo directive chiamato direttametnte sul modulo. Al metodo directive passiamo il nome della direttiva e una funzione che ritorna l'oggetto che rappresenta il codice della direttiva. Nella forma più semplice, l'oggetto ha una proprietà template che specifica il codice HTML che la direttiva deve mostrare. Vediamo ora come usare la direttiva nel codice HTML.
<!DOCTYPE html> <html> <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.4.0/angular.min.js"></script> <body ng-app="myApp"> <my-directive></my-directive> </body> </html>
Come si vede, basta inserire il nome della direttiva come se fosse un normale tag HTML e Angular la tradurrà in automatico per noi.
Il motore delle direttive permette di eseguire operazioni molto più complesse che mostrare un tag HTML. Nei prossimi script vedremo come sfruttare altre funzionalità del motore.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Sfruttare i KeyedService in un'applicazione Blazor in .NET 8
Usare una container image come runner di GitHub Actions
Semplificare il deployment di siti statici con Azure Static Web App
Short-circuiting della Pipeline in ASP.NET Core
Trasformare qualsiasi backend in un servizio GraphQL con Azure API Management
Registrare servizi multipli tramite chiavi in ASP.NET Core 8
.NET Conference Italia 2023
Limitare le richieste lato server con l'interactive routing di Blazor 8
Usare lo spread operator con i collection initializer in C#
Usare un KeyedService di default in ASP.NET Core 8
Reactive form tipizzati con modellazione del FormBuilder in Angular
Applicare il versioning ai nostri endpoint ASP.NET Core Minimal API