Nello script #312 abbiamo analizzato come utilizzare il CSS Grid Model per gestire il layout di una pagina. In questo script entriamo più nel dettaglio analizzando come poter gestire le dimensioni di un div nel quale inseriremo del contenuto.
Una proprietà conoscita ai più, ma al tempo stesso difficile da inserire in un layout "classico", a causa della variabilità della dimensione della viewport del browser, è aspect-ratio. Questa Permette di mantenere la dimensione di un div sulla base di un rapporto altezza / larghezza.
.div-16-9 { aspect-ratio: 16 / 9; } /* quadrato */ .div-1-1 { aspect-ratio: 1 / 1; }
Se la nostra necessità à invece impostare la dimensione di un div, sulla base del testo, possiamo utilizzare la funzione clamp i cui parametri sono dimensione minima, dimensione voluta, dimensione massima
.div-text { width: clamp(30ch, 50%, 80ch); }
E' da notare che non abbiamo impostato una dimensione in px, em o rem, bensì in ch: caratteri. Il div cercherà di occupare il 50% dello spazio disponibile e, al tempo stesso, la larghezza sará tale da mostrare un minimo di 30 fino a un massimo di 80 caratteri per riga.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Miglioramenti agli screen reader e al contrasto in Angular
Utilizzare Model as a Service su Microsoft Azure
Load test di ASP.NET Core con k6
Gestire liste di tipi semplici con Entity Framework Core
Aggiungere interattività lato server in Blazor 8
Visualizzare le change sul plan di Terraform tramite le GitHub Actions
Creazione di componenti personalizzati in React.js con Tailwind CSS
Ottimizzare il mapping di liste di tipi semplici con Entity Framework Core
Creare form tipizzati con Angular
Evitare (o ridurre) il repo-jacking sulle GitHub Actions
Come migrare da una form non tipizzata a una form tipizzata in Angular
Usare le navigation property in QuickGrid di Blazor
I più letti di oggi
- Operazioni di selezione su una DataTable
- annunciato #windowsazure pack: consente di far girare su #windowsserver 2012 e system center on premise i servizi di azure! #msteched
- Aggiungere servizi esterni al ciclo di vita di un'applicazione Silverlight 4.0
- Inviare notifiche toast da background agent con Windows Phone 7.1