Lzh on GitHub

scroll-margin

用于控制吸附容器中项目周围滚动偏移量的工具类。

快速参考

类名样式
scroll-m-<number>scroll-margin: calc(var(--spacing) * <number>);
-scroll-m-<number>scroll-margin: calc(var(--spacing) * -<number>);
scroll-m-(<custom-property>)scroll-margin: var(<custom-property>);
scroll-m-[<value>]scroll-margin: <value>;
scroll-mx-<number>scroll-margin-inline: calc(var(--spacing) * <number>);
-scroll-mx-<number>scroll-margin-inline: calc(var(--spacing) * -<number>);
scroll-mx-(<custom-property>)scroll-margin-inline: var(<custom-property>);
scroll-mx-[<value>]scroll-margin-inline: <value>;
scroll-my-<number>scroll-margin-block: calc(var(--spacing) * <number>);
-scroll-my-<number>scroll-margin-block: calc(var(--spacing) * -<number>);
scroll-my-(<custom-property>)scroll-margin-block: var(<custom-property>);
scroll-my-[<value>]scroll-margin-block: <value>;
scroll-ms-<number>scroll-margin-inline-start: calc(var(--spacing) * <number>);
-scroll-ms-<number>scroll-margin-inline-start: calc(var(--spacing) * -<number>);
scroll-ms-(<custom-property>)scroll-margin-inline-start: var(<custom-property>);
scroll-ms-[<value>]scroll-margin-inline-start: <value>;
scroll-me-<number>scroll-margin-inline-end: calc(var(--spacing) * <number>);
-scroll-me-<number>scroll-margin-inline-end: calc(var(--spacing) * -<number>);
scroll-me-(<custom-property>)scroll-margin-inline-end: var(<custom-property>);
scroll-me-[<value>]scroll-margin-inline-end: <value>;
scroll-mt-<number>scroll-margin-top: calc(var(--spacing) * <number>);
-scroll-mt-<number>scroll-margin-top: calc(var(--spacing) * -<number>);
scroll-mt-(<custom-property>)scroll-margin-top: var(<custom-property>);
scroll-mt-[<value>]scroll-margin-top: <value>;
scroll-mr-<number>scroll-margin-right: calc(var(--spacing) * <number>);
-scroll-mr-<number>scroll-margin-right: calc(var(--spacing) * -<number>);
scroll-mr-(<custom-property>)scroll-margin-right: var(<custom-property>);
scroll-mr-[<value>]scroll-margin-right: <value>;
scroll-mb-<number>scroll-margin-bottom: calc(var(--spacing) * <number>);
-scroll-mb-<number>scroll-margin-bottom: calc(var(--spacing) * -<number>);
scroll-mb-(<custom-property>)scroll-margin-bottom: var(<custom-property>);
scroll-mb-[<value>]scroll-margin-bottom: <value>;
scroll-ml-<number>scroll-margin-left: calc(var(--spacing) * <number>);
-scroll-ml-<number>scroll-margin-left: calc(var(--spacing) * -<number>);
scroll-ml-(<custom-property>)scroll-margin-left: var(<custom-property>);
scroll-ml-[<value>]scroll-margin-left: <value>;

示例

基本示例

使用 scroll-mt-<number>scroll-mr-<number>scroll-mb-<number>scroll-ml-<number> 等工具类,例如 scroll-ml-4scroll-mt-6,来设置吸附容器中项目周围的滚动偏移量:

在图片网格中滚动以查看预期行为

<div class="snap-x ...">
  <div class="snap-start scroll-ml-6 ...">
    <img src="/img/vacation-01.jpg"/>
  </div>
  <div class="snap-start scroll-ml-6 ...">
    <img src="/img/vacation-02.jpg"/>
  </div>
  <div class="snap-start scroll-ml-6 ...">
    <img src="/img/vacation-03.jpg"/>
  </div>
  <div class="snap-start scroll-ml-6 ...">
    <img src="/img/vacation-04.jpg"/>
  </div>
  <div class="snap-start scroll-ml-6 ...">
    <img src="/img/vacation-05.jpg"/>
  </div>
</div>

使用负值

要使用负的滚动外边距值,请在类名前加上一个破折号以将其转换为负值:

<div class="snap-start -scroll-ml-6 ...">
  <!-- ... -->
</div>

使用逻辑属性

使用 scroll-ms-<number>scroll-me-<number> 工具类来设置 scroll-margin-inline-startscroll-margin-inline-end 逻辑属性。这些属性会根据文本方向映射到左侧或右侧:

在图片网格中滚动以查看预期行为

Left-to-right

Right-to-left

<div dir="ltr">
  <div class="snap-x ...">
    <div class="snap-start scroll-ms-6 ...">
      <img src="/img/vacation-01.jpg"/>
    </div>
    <!-- ... -->
  </div>
</div>
<div dir="rtl">
  <div class="snap-x ...">
    <div class="snap-start scroll-ms-6 ...">
      <img src="/img/vacation-01.jpg"/>
    </div>
    <!-- ... -->
  </div>
</div>

如需更多控制,你还可以使用 LTR 和 RTL 修改器 来根据当前的文本方向有条件地应用特定样式。

使用自定义值

使用 scroll-ml-[<value>]scroll-me-[<value>] 等工具类,可以根据完全自定义的值来设置滚动外边距

<div class="scroll-ml-[24rem] ...">
  <!-- ... -->
</div>

对于 CSS 变量,你还可以使用 scroll-ml-(<custom-property>) 语法:

<div class="scroll-ml-(--my-scroll-margin) ...">
  <!-- ... -->
</div>

这只是 scroll-ml-[var(<custom-property>)] 的一个简写,它会自动为你添加 var() 函数。

响应式设计

scroll-margin 工具类前加上 md:断点变体,使其仅在中等屏幕尺寸及以上应用:

<div class="scroll-m-8 md:scroll-m-0 ...">
  <!-- ... -->
</div>

变体文档 中了解更多关于使用变体的信息。

自定义你的主题

scroll-m-<number>scroll-mx-<number>scroll-my-<number>scroll-ms-<number>scroll-me-<number>scroll-mt-<number>scroll-mr-<number>scroll-mb-<number>scroll-ml-<number> 等工具类由 --spacing 主题变量驱动,该变量可以在你自己的主题中进行自定义:

@theme {
  --spacing: 1px; 
}

主题变量文档 中了解更多关于自定义间距比例的信息。