Il Clip-path è una proprietà CSS rilasciata nel 2016. Perché, pur essendo disponibile da così tanto tempo, non ne sentiamo mai parlare e, soprattutto, a cosa potrebbe servirci per la nostra libreria CSS?
Lo scopo del Clip-path è semplice: crea una forma geometrica all'interno dell'elemento in cui viene applicata, rendendo visibile tutto quello che vi è all'interno e invisibile ciò che stà all'esterno. Il problema nel suo utilizzo è proprio nella descrizione: creare una forma geometrica e gestirla non è banale.
Facciamo un esempio di un div che tramite la proprietà scomparirà verso il centro formando un cerchio e si riaprirà a metà dell'animazione
.box {
animation: circle 3s infinite;
background: orange;
height: 200px;
width: 200px;
}
@keyframes circle {
/* un cerchio con raggio 75% delle dimensioni del quadrato è sufficiente a coprire tutta l'area del quadrato */
0% { clip-path: circle(75%); }
50% { clip-path: circle(25%); }
100% { clip-path: circle(75%); }
}Se volessimo spostare il centraggio dell'animazione, possiamo utilizzare il secondo argomento, per definire la posizione spaziale della forma
@keyframes circle {
/* [...] */
/* cerchio che si chiuderà verso il lato sinistro*/
50% { clip-path: circle(25% 0%); }
/* cerchio che si chiuderà a metà strada tra il centro e il lato destro*/
50% { clip-path: circle(25% 75%); }
/* [...] */
}Il cerchio non è la sola forma disponibile, troviamo anche: Ellipse, Inset per un rettangolo a cui definire i bordi e il raggio, polygon che ci permette di creare forme complesse.
Ora che ne abbiamo dato una definizione, come può tornarci utile? Applicandola ad un button, una card, un link o una voce di menù, possiamo creare animazioni all'hover, ad un cambio stato o cicliche tramite animazioni.
Nel codice sottostante l'effetto è un riempimento dall'interno verso l'esterno di colore arancione in fase di hover. Dato che Clip-path lavora sulla visibilità non possiamo applicarla direttamente al bottone, utilizziamo quindi il before dell'elemento.
<style>
.btn-clip {
position: relative;
overflow: hidden;
background: transparent;
color:black;
transition: 0.5s ease-in-out;
}
.btn-clip::before {
content: '';
position: absolute;
inset: 0;
background-color: #ff5722;
clip-path: circle(0% at 50% 50%);
transition: 0.5s ease-in-out;
}
.btn-clip span{
/* permette al testo di stare sempre sopra tutti gli altri elementi */
position:relative;
z-index: 1;
}
.btn-clip:hover {
color:#fff;
}
.btn-clip:hover::before {
clip-path: circle(100% at 50% 50%);
}
</style>
<a href="#" class="btn-clip btn btn-secondary"><span>Hover me</span></a>Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Usare la libreria PredicateBuilder per eseguire query tramite Entity Framework che usano or su più campi
Arricchire l'interfaccia di .NET Aspire
Abilitare automaticamente il force push di un gruppo su Azure DevOps
Introduzione alle Container Queries
Integrare un servizio esterno con .NET Aspire
Evidenziare una porzione di testo in un pagina dopo una navigazione
Gestione file Javascript in Blazor con .NET 9
Path addizionali per gli asset in ASP.NET Core MVC
Proteggere l'endpoint dell'agente A2A delle Logic App
Controllare la velocità di spostamento su una pagina HTML
Utilizzare il metodo Index di LINQ per scorrere una lista sapendo anche l'indice dell'elemento
Definire il colore di una scrollbar HTML tramite CSS
I più letti di oggi
- Effettuare il multi-checkout in linea nelle pipeline di Azure DevOps
- Gli oggetti CallOut di Expression Blend 4.0
- Esaminare documenti XML con namespace utilizzando LINQ to XML
- Alleggerire le applicazioni WPF sfruttando gli oggetti Freezable
- Utilizzare dati in formato XML in XAML
- Le DirectInk API nella Universal Windows Platform
- Sfruttare una CDN con i bundle di ASP.NET


