CSS scroll-margin-block Property
Set the distance to the scrollable container from a snap position in the block direction:
More "Try it Yourself" examples below.
Definition and Usage
scroll-margin-block property specifies the distance in block direction, between the snap position and the container.
This means that when you stop scrolling, the scrolling will quickly adjust and stop at a specified distance in block direction, between the snap position and the container.
Block direction is where the next line is put compared to the position of an existing line, and this is also how tags with CSS
display: block; like <p> and <div> tags are laid out on a page. Block direction is dependent on the written language, i.e. Mongolian where new lines are laid out left to right which makes block direction left to right, while pages in English have a downward block direction. Block direction can be defined with CSS property
Snap position is the position on the child element where it snaps into place in the container when you stop scrolling.
Note: This property only works if the scroll-snap-align property is set to 'start' or 'end' for the block direction.
scroll-margin-block property is a shorthand property for the following properties:
Values for the
scroll-margin-block property can be set in different ways:
If the scroll-margin-block property has two values:
- scroll-margin-block: 10px 50px;
- distance at start is 10px
- distance at end is 50px
If the scroll-margin-block property has one value:
- scroll-margin-block: 10px;
- distance at start and end is 10px
To see the effect from the
scroll-margin-block property, the
scroll-snap-align properties must be set on the child elements, and the
scroll-snap-type property must be set on the parent element.
scroll-margin-block properties are very similar to CSS properties
scroll-margin-right, but the
scroll-margin-inline properties are dependent on block and inline directions.
|Animatable:||no. Read about animatable|
The numbers in the table specify the first browser version that fully supports the property.
|0||Default. The element's default scroll-margin-block value.|
|length||Specifies distance in px, pt, cm, etc. Negative values are allowed. Read about length units|
|initial||Sets this property to its default value. Read about initial|
|inherit||Inherits this property from its parent element. Read about inherit|
writing-mode property value of a child element set to vertical-rl, the start of the element in block direction is moved from top to right side, and the end of the element is moved from bottom to left side. This affects the scroll snap behaviour, and how the scroll-margin-block property works:
scroll-margin-block: 20px 0;
CSS scroll-margin-block-end property: CSS scroll-margin-block-end property
CSS scroll-margin-block-start property: CSS scroll-margin-block-start property
CSS scroll-snap-align property: CSS Scroll-snap-align property
CSS scroll-snap-type property: CSS Scroll-snap-type property
CSS writing-mode property: CSS Writing-mode property