CSS scroll-margin-inline-end
La proprietà CSS3 scroll-margin-inline-end imposta un margine orizzontale alla fine
La proprietà scroll-margin-inline-end
definisce lo spazio orizzontale alla fine dell'asse logico inline quando un elemento viene scrollato in vista. Questo permette un migliore posizionamento visivo in base alla direzione del testo, sia in layout LTR che RTL.
Sintassi
Significato dei valori principali:
-
lunghezza: valore che definisce il margine alla fine dell’asse orizzontale logico (
inline-end
). Accetta unità comepx
,em
,rem
, ecc.
In un layout LTR, corrisponde al margine destro; in un layout RTL, al margine sinistro.
Esempio proprietà: scroll-margin-inline-end
Codice Esempio: scroll-margin-inline-end

html {
scroll-behavior: smooth;
}
.scroll-container {
text-align: left;
width: 262px;
height: 250px;
overflow-x: scroll;
display: flex;
box-sizing: border-box;
border: 5px solid #222;
scroll-snap-type: x mandatory;
}
.box {
flex: 0 0 250px;
width: 250px;
background-color: #56b6c2;
color: #fff;
font-size: 30px;
display: flex;
align-items: center;
justify-content: center;
scroll-snap-align: end;
border: 1px solid #fff;
border-radius: 10px;
}
.target-right {
scroll-margin-inline-end: 50px;
background-color: #e06c75;
}
Contenuto Esempio: scroll-margin-inline-end
📌 Nota sull’utilizzo delle proprietà scroll-*
Le proprietà della famiglia scroll-*
offrono controllo preciso sul comportamento e sul posizionamento dello scroll nei contenitori overflow. Tuttavia, la loro efficacia può variare in base al tipo di interazione, al contesto e al metodo di attivazione dello scroll. Di seguito una panoramica generale:
-
scroll-behavior
: controlla se lo scroll avviene in modo fluido (smooth
) o istantaneo (auto
). È supportata in interazioni utente (tastiera, mouse) e via JavaScript con metodi comescrollIntoView()
oscrollTo()
. -
scroll-margin*
: imposta uno spazio esterno virtuale tra il target dello scroll e il bordo del contenitore. È utile per evitare che l’elemento scrollato venga troppo "incollato" al bordo. Agisce solo quando l’elemento è il target di scroll (es.scrollIntoView()
). -
scroll-padding*
: definisce un’area interna del contenitore da considerare come "bordo attivo" per gli snap o il focus di scroll. È efficace nei contenitori conscroll-snap-type
attivo o nei layout con focus automatico. -
scroll-snap-type
: abilita lo snap agli elementi figlio durante lo scroll, obbligando (o suggerendo) l’aggancio al più vicino snap-point. Richiede layout a scorrimento (overflow
) e funzionerà solo se associato a elementi figli conscroll-snap-align
. -
scroll-snap-align
: definisce dove un elemento figlio deve "agganciarsi" all'interno del contenitore scrollabile (es. inizio, centro, fine). Funziona solo se il contenitore hascroll-snap-type
. -
scroll-snap-stop
: impedisce che l’elemento venga saltato durante uno scroll veloce. Utile per forzare lo stop su sezioni importanti, ma funziona solo con scroll naturali (touch, tastiera, oscrollIntoView
), non conscrollTo({ left: ... })
.
Compatibilità e contesto: molte di queste proprietà funzionano meglio con interazioni naturali (touchpad, touchscreen, tastiera) e possono non comportarsi come previsto quando lo scroll è simulato in modo diretto con JavaScript. Per ottenere effetti coerenti, è consigliato usare layout con display: flex
o grid
, dimensioni fisse e contenitori overflow con scroll-snap-type
attivo.
Prova questo esempio
DEMO
Note:
Le indicazioni dei Browser supportati sono superate grazie alla loro costante evoluzione, si consiglia di verificare la compatibilità dei vari browser eseguendo il test cliccando qui sotto.