• CSS滚动捕获 scroll-snap-align


    CSS滚动捕获 scroll-snap-align

    看到 align, 就条件反射想到对齐方式, 嗯猜对了. 不过要先看一下若干名词介绍

    scroll-snap-align 指定了盒子的 snap position, 即盒子 snap area 和滚动容器的 snapport 的对齐方式.

    这个属性是定义在滚动元素上, 而不是滚动容器上

    语法

    这个属性可以指定两个值, 分别表示 y(块方向) 轴和 x(内联方向) 轴的对齐. 如果只指定一个值, 那么第二个值保持相同.

    • none: 默认值, 无滚动捕获行为.

    • start: 盒子的 snap position 的顶部与 snapport 顶部对齐

      • 在这里插入图片描述
    • end: 盒子的 snap position 的尾部与 snapport 尾部对齐

      • 在这里插入图片描述
    • center: 盒子的 snap position 的中间与 snapport 中间对齐

      • 在这里插入图片描述

    和 scroll-margin 的关系

    在前面的定义中已经说过了, 这个属性对齐的不是盒子的 border box 而是盒子 snap area, 即 border box 加上 scroll-margin

    我们来点 CSS, 给滚动容器的第二个元素加上 40pxscroll-margin-top

    .item {
      scroll-snap-align: center;
    }
    .item:nth-child(2) {
      scroll-margin-top: 40px;
    }
    .item:nth-child(2)::before {
      content: '';
      height: 40px;
      outline: 2px dashed #111;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    元素都是居中对齐, 但是第二个元素算居中位置的时候把 40px 也加上了. 好家伙

    在这里插入图片描述

    和 scroll-padding 的关系

    同样是前面的定义, 对齐不是发生在滚动容器上, 而是滚动容器的 snapport 上, 即滚动容器减去其 scroll-padding.

    📖 注意 scroll-padding 并不像 padding 一样会渲染出高度, 但是它有它的位置.

    .container {
      overflow: scroll;
      scroll-snap-type: y mandatory;
      scroll-padding-top: 40px;
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5

    你会发现, 元素对齐区域变成了黑色虚线下面的区域, 而不再是整个滚动容器.

    在这里插入图片描述

    最后大家可以手动试一下, 加上 scroll-paddingscroll-margin 双重 buff 的滚动捕获时什么样的.

    兼容性

    在这里插入图片描述

    谢谢你看到这里😊 大家周末开心呀

  • 相关阅读:
    前后端分离--Vue的入门基础版
    有什么副业能日入100-300+呢?
    刘二大人 PyTorch深度学习实践 笔记 P11 卷积神经网络(高级篇)
    flutter:监听路由的变化
    AcWing 1289. 序列的第k个数
    ConcurrentHashMap:并发的hashmap
    长时间对着电脑,女子眼里长出多颗结石,俞存提醒这些人群要注意
    operator-sdk入门(mac)
    如何在电脑上设置新的蓝牙耳机
    【算法小讲堂】#1 贪心算法
  • 原文地址:https://blog.csdn.net/broken_promise/article/details/134474704