试一试
scroll-margin-block: 0;
scroll-margin-block: 20px;
scroll-margin-block: 2em;
<section class="default-example" id="default-example">
<div class="scroller">
<div>1</div>
<div id="example-element">2</div>
<div>3</div>
</div>
<div class="info">Scroll »</div>
</section>
.default-example .info {
inline-size: 100%;
padding: 0.5em 0;
font-size: 90%;
writing-mode: vertical-rl;
}
.scroller {
text-align: left;
height: 250px;
width: 270px;
overflow-y: scroll;
display: flex;
flex-direction: column;
box-sizing: border-box;
border: 1px solid black;
scroll-snap-type: y mandatory;
}
.scroller > div {
flex: 0 0 250px;
background-color: rebeccapurple;
color: white;
font-size: 30px;
display: flex;
align-items: center;
justify-content: center;
scroll-snap-align: start;
}
.scroller > div:nth-child(even) {
background-color: white;
color: rebeccapurple;
}
构成属性
此属性是以下 CSS 属性的简写:
语法
css
/* <length> values */
scroll-margin-block: 10px;
scroll-margin-block: 1em 0.5em;
/* Global values */
scroll-margin-block: inherit;
scroll-margin-block: initial;
scroll-margin-block: revert;
scroll-margin-block: revert-layer;
scroll-margin-block: unset;
值
<length>-
从滚动容器的相应边缘向外扩展的距离。
描述
scroll-margin 值表示外延,它们定义了滚动捕捉区域,该区域用于将此框捕捉到捕捉视区。滚动捕捉区域是通过获取变换后的边框,找到其矩形边界框(在滚动容器的坐标空间中与轴对齐),然后添加指定的外部偏移量来确定的。
正式定义
| 初始值 | 作为简写中的每个属性 |
|---|---|
| 应用于 | 所有元素 |
| 继承性 | 否 |
| 计算值 | 作为简写中的每个属性
|
| 动画类型 | 按计算值类型 |
正式语法
scroll-margin-block =
<length>{1,2}
规范
| 规范 |
|---|
| CSS 滚动捕捉模块级别 1 # propdef-scroll-margin-block |
浏览器兼容性
加载中…