如何防止多列布局中的列表项内部出现分栏?
防止元素内的分栏
使用多列布局时,通常会遇到分栏意外分割元素的问题。当元素(例如列表项)太长而无法容纳在单个列中时,就会发生这种情况。
问题陈述
考虑以下 HTML 和 CSS:
<div class='x'> <ul> <li>Number one</li> <li>Number two</li> <li>Number three</li> <li>Number four is a bit longer</li> <li>Number five</li> </ul> </div>
登录后复制
.x { -moz-column-count: 3; column-count: 3; width: 30em; }
登录后复制
在这种情况下,某些列表项可能会在列之间拆分,如下所示渲染:
• Number one • Number three bit longer • Number two • Number four is a • Number five
登录后复制
目标是防止这种分裂,实现更理想的渲染,如:
• Number one • Number four is a • Number two bit longer • Number three • Number five
登录后复制
解决方案:break-inside Property
这个问题的解决方案在于利用CSS的break-inside属性。通过在您希望防止破坏的元素上设置break-inside:avoid-column,您可以指示浏览器将该元素保留在单个列中。
.x li { break-inside: avoid-column; }
登录后复制
这种方法得到了主流浏览器的广泛支持,包括 Chrome 和 Safari。然而,截至 2021 年 10 月,Firefox 仍然缺乏对break-inside 属性的支持。
Firefox 解决方法
对于 Firefox,存在涉及使用表的解决方法。但是,由于其负面影响,强烈建议不要使用此解决方案。
Firefox 20 中的分页内部支持
根据 Firefox 错误报告(错误 549114) ,Firefox 20 及更高版本现在支持使用 page-break-inside:void 来防止元素内出现分栏。但是,如以下代码片段所示,此方法尚未完全解决列表的问题:
.x { column-count: 3; width: 30em; } .x ul { margin: 0; } .x li { -webkit-column-break-inside: avoid; -moz-column-break-inside:avoid; -moz-page-break-inside:avoid; page-break-inside: avoid; break-inside: avoid-column; }
登录后复制
<div class='x'> <ul> <li>Number one, one, one, one, one</li> <li>Number two, two, two, two, two, two, two, two, two, two, two, two</li> <li>Number three</li> </ul> </div>
登录后复制
以上是如何防止多列布局中的列表项内部出现分栏?的详细内容。更多信息请关注PHP中文网其他相关文章!
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章
Windows 11 KB5054979中的新功能以及如何解决更新问题
4 周前
By DDD
如何修复KB5055523无法在Windows 11中安装?
3 周前
By DDD
Inzoi:如何申请学校和大学
1 个月前
By DDD
如何修复KB5055518无法在Windows 10中安装?
3 周前
By DDD
在哪里可以找到Atomfall中的站点办公室钥匙
1 个月前
By DDD

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)