scroll-marker轮播组件不再难

在开发轮播组件时,我们不仅要写每一屏的内容,还要写指示器的样式。每一屏都需要一个指示器,指示器的样式也需要写。还需要写指示器的点击事件,指示器数量还需要和内容的数量保持一致。

scroll-marker-group

scroll-marker-group 属性用于标记是否在滚动容器内生成伪元素 ::scroll-marker-group,以及生成的位置。

html 复制代码
<ul class="scroll-container">
  <li class="scroll-target"></li>
  <li class="scroll-target"></li>
  <li class="scroll-target"></li>
  <li class="scroll-target"></li>
  <li class="scroll-target"></li>
</ul>

应用下面的样式后,滚动容器内会生成伪元素 ::scroll-marker-group

css 复制代码
.scroll-container {
  --width: 200px;
  width: var(--width);
  aspect-ratio: 2;
  scroll-marker-group: after;
  display: flex;
  overflow: hidden;

  .scroll-target {
    width: var(--width);
    height: 100%;
    flex-shrink: 0;
    background-color: attr(data-color type(<color>));
  }
}

但是现在还没有指示器,如下图,我们需要写指示器的样式。

css 复制代码
.scroll-container {
  --width: 200px;
  width: var(--width);
  aspect-ratio: 2;
  scroll-marker-group: after;
  display: flex;
  overflow: hidden;
  scroll-behavior: smooth;
  anchor-name: --refer;

  &::scroll-marker-group {
    display: flex;
    gap: 5px;
    position: absolute;
    position-anchor: --refer;
    bottom: calc(anchor(bottom) + 10px);
    justify-self: anchor-center;
  }

  .scroll-target {
    width: var(--width);
    height: 100%;
    flex-shrink: 0;
    background-color: attr(data-color type(<color>));

    &::scroll-marker {
      content: "";
      width: 10px;
      height: 10px;
      border: 1px solid black;
      border-radius: 50%;
    }
  }
}

如下图,这样就在滚动容器内下部边缘生成了指示器,且点击指示器可以滚动到对应的内容。是不是特别方便

但是这样的指示器无法看出来当前显示的是哪一个内容,我们需要通过:target-current伪类来标记当前显示的内容,添加特殊样式

css 复制代码
.scroll-target::scroll-marker:target-current {
  background-color: black;
}

如下图,这样就可以看到当前显示的是哪一个内容了。

除了上面提到的::scroll-marker-group::scroll-marker 还有::scroll-button 属性,它可以生成按钮,是轮播组件的上一个下一个按钮。这样就可以不需要写指示器。就不展示了

兼容性

chrome,edge已经支持了,其它浏览器还要再等等


文中除了scroll相关的,还用到anchorattr。感兴趣的可以留言讨论

相关推荐
NiceCloud喜云4 小时前
Opus 4.8 的 Effort Control 怎么选:Low 到 Max 五档策略
android·java·大数据·前端·c++·python·spring
wordbaby5 小时前
React Native + RNOH:跨页面数据回传的最佳实践与避坑指南
前端·react native
丷丩5 小时前
MapLibre GL JS第22课:查看本地GeoJSON
前端·javascript·map·mapbox·maplibre gl js
Front思6 小时前
AI前端工程师需要具备能力+
前端·人工智能·ai
ZC跨境爬虫8 小时前
跟着 MDN 学CSS day_29:(掌握文本与字体样式的核心艺术)
前端·css·ui·html·tensorflow
李子琪。9 小时前
网络空间安全深度实战:CSRF 漏洞原理剖析与基于 Token 的纵深防御体系构建(全栈实验报告)
前端·安全·csrf
冰暮流星9 小时前
javascript之history对象介绍
前端·笔记
IT_陈寒9 小时前
Vite热更新失灵?你可能漏了这个配置
前端·人工智能·后端
丷丩9 小时前
MapLibre GL JS第19课:实时更新要素
前端·javascript·gis·map·mapbox·maplibre gl js
Mr.Daozhi9 小时前
RAG 进阶实战:跑通 Demo 后我连续翻了 6 次车,逐一修复才真正可用(含 Gradio Web 版)
前端·数据库·langchain·大模型·gradio·rag·科研工具