溢出式菜单

CSS 播客 - 第 034 集:溢出

当内容超出其父级时,您可以通过多种方式进行处理。您可以滚动屏幕以添加更多空间、剪裁超出边缘的内容、使用省略号指明被截断的内容,等等。在针对手机应用和多种屏幕尺寸开发时,请务必考虑溢出问题。

CSS 中有两种不同的剪裁选项;text-overflow 有助于处理单行文本,overflow 属性有助于控制边框模型中的溢出。

使用 text-overflow 的单行溢出

对包含文本节点的任何元素(例如段落 <p>)使用 text-overflow 属性。它用于指定当文本不适合元素的可用空间时,文本的显示方式。网页上所有可见的 HTML 文本都位于文本节点中。如需使用 text-overflow,您需要使用一行未换行的文本,因此您还必须将 overflow 设置为 hidden,并使用可防止换行的 white-space 值。

p {
    text-overflow: ellipsis;
    overflow: hidden;
    white-space: nowrap;
}

使用溢出属性

在元素上设置溢出属性,以控制当其子元素需要的空间超出其可用空间时会发生什么情况。这可能是有意为之,例如在 Google 地图等交互式地图中,用户可以平移剪裁为特定大小的大型图片。它也可能是无意的,例如在聊天应用中,用户输入的长消息超出了文本气泡的显示范围。

您可以将溢出分为两部分。父元素具有固定的空间限制,不会发生变化。您可以将其视为一个窗口。子元素是需要从父元素获得更多空间的内容。您可以将其视为您透过窗户看到的内容。管理溢出有助于指导窗口如何框定此内容。

在纵轴和横轴上滚动

overflow-y 属性用于控制设备视口垂直轴的实际溢出,因此会上下滚动。

overflow-x 属性用于控制设备视口的水平轴上的溢出,从而实现左右滚动。

滚动方向的逻辑属性

Browser Support

  • Chrome: not supported.
  • Edge: not supported.
  • Firefox: 69.
  • Safari: not supported.

Source

overflow-inlineoverflow-block 属性会根据文档方向和写入模式设置溢出。

overflow 简写法

overflow 简写形式可在一行中同时设置 overflow-xoverflow-y 样式:

overflow: hidden scroll;

如果指定了两个关键字,第一个关键字会应用于 overflow-x,第二个关键字会应用于 overflow-y。否则,overflow-xoverflow-y 会使用相同的值。

我们来详细了解一下 overflow 媒体资源可用的值和关键字

overflow: visible(默认)
如果未设置此属性,则 overflow: visible 是网站的默认值。这样可以确保内容不会无意中被隐藏,并遵循“绝不隐藏内容”或“精确布局的安全布局”等核心原则。
overflow: hidden
使用 overflow: hidden 时,系统会沿指定方向剪裁内容,并且不会提供滚动条来显示内容。
overflow: scroll
overflow: scroll 用于启用滚动条,以便用户滚动浏览内容。即使内容目前没有溢出,滚动条也会显示。如果容器将来可能会根据(例如)大小调整而可滚动,这是一个减少未来布局偏移的好方法,可让用户在视觉上为可滚动区域做好准备。
overflow: clip
overflow: hidden 一样,使用 overflow: clip 的内容会被剪裁到元素的内边距盒。cliphidden 之间的区别在于,clip 关键字还会禁止所有滚动,包括程序化滚动。
overflow: auto
最后,最常用的值是 overflow: auto。这会遵循用户的偏好设置,并在需要时显示滚动条,但默认情况下会隐藏滚动条,并将滚动操作的责任交给用户和浏览器。

滚动和溢出

其中许多 overflow 行为都会引入滚动条,但有一些特定的滚动行为和属性可以帮助您控制溢出容器上的滚动。

滚动和无障碍功能

请务必确保可滚动区域可以接受焦点,以便键盘用户可以按 Tab 键找到该框,然后使用箭头键滚动。

如需允许滚动框接受焦点,请添加 tabindex="0"、带有 aria-labelledby 属性的名称以及适当的 role 属性。例如:

<div tabindex="0" role="region" aria-labelledby="id-of-descriptive-text">
    content
</div>

然后,您可以使用 CSS 指明该框已获得焦点,并使用 outline 属性提供视觉提示,表明该框现在可滚动。

Using CSS to Enforce Accessibility 中,Adrian Roselli 演示了 CSS 如何帮助防止无障碍功能回归。例如,仅在使用正确的属性时启用滚动功能并添加焦点指示器。只有当框具有 tabindexaria-labelledbyrole 属性时,以下规则才会使其可滚动。

[role][aria-labelledby][tabindex] {
  overflow: auto;
}

[role][aria-labelledby][tabindex]:focus {
  outline: .1em solid blue;
}

滚动条在盒模型中的定位

滚动条会占用内边距框内的空间,如果为 inline(而非 overlaid),则可能会争夺空间。盒模型模块详细介绍了此可能导致布局偏移的原因。

root-scroller 与 implicit-scroller

您可能会注意到,某些滚动条具有“拉动以刷新”行为和其他特殊行为,尤其是在针对移动应用和混合应用进行开发时。此滚动行为会在根滚动器上发生。网页上只能有一个根滚动条。默认情况下,documentElement 是页面的根滚动条,不过,通过更改根滚动条元素,您可以将特殊行为应用于 documentElement 以外的滚动条,我们将此新滚动条称为隐式根滚动条。

如需创建根滚动条,您可以使用所谓的滚动条提升功能,方法是将容器定位为固定,确保其覆盖整个视口,并且 z-index 位于滚动条之上。如需体验根滚动条与嵌套的隐式滚动条的区别,请点击此处

该视频展示了具有弹跳行为和新样式功能的根滚动条,
与滚动不带增强型滚动行为的隐式滚动条相比。

scroll-behavior

Browser Support

  • Chrome: 61.
  • Edge: 79.
  • Firefox: 36.
  • Safari: 15.4.

Source

借助 scroll-behavior,您可以选择启用浏览器控制的元素滚动。这样,您就可以指定如何处理 .scrollTo() 或链接等页内导航。

prefers-reduced-motion 搭配使用时,此属性尤为有用,可根据用户偏好设置指定滚动行为。

@media (prefers-reduced-motion: no-preference) {
  .scroll-view {
    scroll-behavior: auto;
  }
}

overscroll-behavior

Browser Support

  • Chrome: 63.
  • Edge: 18.
  • Firefox: 59.
  • Safari: 16.

Source

如果您曾经到达模态叠加层的末尾,然后继续滚动,并使叠加层后面的页面移动,这就是滚动链接,或向上冒泡到父级滚动容器。借助 overscroll-behavior 属性,您可以防止溢出滚动渗漏到父级容器(称为滚动链接)。

检查您的理解情况

测试您对溢出相关知识的掌握情况

文本溢出和元素溢出是否相同?

true
与元素溢出相比,文本溢出具有特殊性。
false
文本溢出通常与内嵌溢出有关,而元素溢出与块溢出有关。

overflow 属性接受 2 个关键字,第一个关键字是用于哪个轴?

横向
🎉
类别
在传递两个缩写值时,第一个值几乎总是水平的。

滚动条在显示和内嵌时会占用盒模型中的哪些空间?

内容框
再试一次!
内边距框
overlay 模式下的滚动条会与内边距重叠,而在 inline 模式下,滚动条会增加内边距。
边框
再试一次!
边距盒
再试一次!

如需捕获嵌套隐式滚动器中的滚动额外动量,您将使用哪个属性?

scroll-behavior
再试一次!
scroll-hint
再试一次!
overscroll-behavior
将此属性设置为 contain 会捕获滚动。
scroll-padding
再试一次!
overscroll-effect
再试一次!

资源

Smashing Magazine 中的“CSS 中的溢出和数据丢失”一文