CSS文本平衡排版 text-wrap:balance

简介: CSS文本平衡排版 text-wrap:balance

本文翻译自 CSS Text balancing with text-wrap:balance,略有删改

您是否曾经希望 CSS 中有一种原生能力可以使两行标题在每行字数上保持一致?作为一名设计师,我在设计网站或 UI 时处理不同的内容长度时经常发现这一点。

这样的情况会让你感觉 UI 效果不平衡,或者缺少一些东西。如下图所示:

突出显示的单词是位于一行中的单个单词。从视觉的角度来看,这看起来很奇怪,它打破了原本的视觉设计效果。

当我在像 Figma 这样的工具中进行设计时,我故意将最后一个词移到上一行,只是为了避免这种不一致的问题。

这样看起来效果是不是更好呢?

在代码中,如果平衡很重要,我们可以通过使用 <br> 手动完成,或者用 <span> 分隔内容的另一部分。还有一些方法可以通过使用 <wbr> 元素而不是句子来提示浏览器何时打断单词。

还有有一个名为 React Wrap Balancer 的 React 组件,也可以使文本在调整大小时动态平衡。

CSS 中的文本平衡

幸运的是,我们现在在 Chrome Canary 版本中对 text-wrap: balance 提供了实验性支持。浏览器会自动计算单词的数量,并将它们平分在两行中。

我们只需要应用CSS text-wrap: property 属性。

.c-hero__title {
    max-width: 36rem;
    text-wrap: balance;
}

这样,标题内容就会平衡,不会在某一行中有一个单词。

接下来让我们更详细地探讨一下。

在元素上设置 Max-Width 的文本平衡

请注意,使用文本平衡不会影响元素的宽度。如下图所示。

标题的最大宽度为 630px 。当有 text-wrap: balance 时,会对齐每行字数,max-width 不受影响。

同样的事情也会发生在容器很小的时候,比如卡片标题。它只会影响容器中的单词。

用例和示例

让我们探索一下 text-wrap: balance 的用处。

页面标题

页面标题是可能首先吸引用户眼球的东西。这是一个没有平衡的例子:

使用之后的效果。

卡片标题

这是一种常见的模式,您可能会在其中发现具有不同标题的文章列表。

使用之后的效果。

提示文字

我们经常会使用工具提示向用户显示重要信息,它可能是几个字或多行。 下面这个提示,其中有一个单词位于单独一行中。

增加 text-wrap: balance后的效果。

.tooltip p {
    text-wrap: balance;
}

Modal标题

我们可能有一个跨越多行的Modal标题,在它的最后一行中看到一个单词可能会在视觉上感觉不太友好。

增加 text-wrap: balance后的效果。

FAQ

另一个我认为 text-wrap: balance 有很大潜力的例子是常见问题解答列表。

增加 text-wrap: balance后的效果。

文本平衡不会影响元素的宽度

当无法控制元素宽度时,我不确定是否使用 text-wrap: balance 。在某些设计中,它会留下很大的空间,使设计在我看来更糟。

注意粉红色轮廓中文本的宽度。应用文本平衡后,宽度将保持不变,只有文本会重新排序。这会让右侧留下一个很大的空白,会使设计效果不平衡。所以针对这类固定宽度的场景需要斟酌使用。

性能限制

目前,该功能仅限于 4 行。也就是说,它主要用于标题或几行的段落。

参考

css-text-wrap-balance

valdef-text-wrap-balance

最后

这是一个很不错且实用的功能,应用到的场景也挺多,但是目前还是在实验阶段,真正可以线上环境使用还需要一定的时间,但是可以提前了解一下发展的趋势。看完本文如果觉得有用,记得点个赞支持,收藏起来说不定哪天就用上啦~


目录
相关文章
|
2月前
|
前端开发
前端基础(五)_CSS文本文字属性、背景颜色属性
本文详细介绍了CSS中关于文本和背景颜色的样式属性。包括字体大小、字体族、字体加粗、字体样式、文本行高、`font`属性、文本颜色、文本对齐方式、文本装饰线、首行缩进等文本属性,以及背景颜色、背景图片、背景重复、背景位置等背景属性。文章通过示例代码展示了这些属性的具体应用和效果。
30 3
前端基础(五)_CSS文本文字属性、背景颜色属性
|
2月前
|
前端开发
【前端web入门第三天】02 CSS字体和文本
本文详细介绍了CSS中字体和文本的相关属性。字体部分涵盖字体大小、粗细、样式、行高、字体族及`font`复合属性,通过具体示例展示了如何设置和使用这些属性。文本部分则讲解了文本缩进、对齐方式、修饰线及文字颜色等属性,并提供了实用的代码示例。此外,还简要介绍了调试工具中的一些细节,如错误属性标识和属性生效状态的控制。
64 28
|
3月前
|
前端开发
使用CSS样式化占位文本
使用CSS样式化占位文本
20 0
|
4月前
|
前端开发 JavaScript
文本,wangEditor5展示HTML无样式,wangEditor5如何看源码,Ctrl + U看CSS文件,代码高亮,Prism.js可以实现,解决方法,参考网页源代码的写法
文本,wangEditor5展示HTML无样式,wangEditor5如何看源码,Ctrl + U看CSS文件,代码高亮,Prism.js可以实现,解决方法,参考网页源代码的写法
|
3月前
|
前端开发 容器
CSS实现多行文本的展开收起
CSS实现多行文本的展开收起
38 0
|
4月前
|
前端开发
你不知道的css——4. 基线、中线、x-height、单位ex(含文本与图标对齐技巧)
你不知道的css——4. 基线、中线、x-height、单位ex(含文本与图标对齐技巧)
53 2
|
5月前
|
前端开发 UED
深入理解CSS中的文本对齐方式:水平对齐与垂直对齐
深入理解CSS中的文本对齐方式:水平对齐与垂直对齐
112 5
|
4月前
|
前端开发 容器
css 动态文本对齐自适应 — 文本宽度小于容器宽度时居中对齐,文本宽度大于容器宽度时居左对齐
css 动态文本对齐自适应 — 文本宽度小于容器宽度时居中对齐,文本宽度大于容器宽度时居左对齐
39 2
|
4月前
|
JavaScript 前端开发
vue 模拟随机变速的动态打字特效【支持多行文本】(含css实现闪烁光标,js动态改变setInterval定时器的时间间隔)
vue 模拟随机变速的动态打字特效【支持多行文本】(含css实现闪烁光标,js动态改变setInterval定时器的时间间隔)
91 1
|
5月前
|
移动开发 前端开发 HTML5
有关CSS中排版常见问题(清除默认样式问题 + 元素居中问题 + 元素之间的空白问题 + 行内块的幽灵空白问题)
有关CSS中排版常见问题(清除默认样式问题 + 元素居中问题 + 元素之间的空白问题 + 行内块的幽灵空白问题)