首页 web前端 css教程 为什么我的没有按预期缩小?它似乎有一个不可移除的 min-width: min-content 问题。

为什么我的没有按预期缩小?它似乎有一个不可移除的 min-width: min-content 问题。

Nov 09, 2024 pm 10:44 PM

Why does my  not shrink as expected? It seems to have a non-removable min-width: min-content problem.

无法按预期缩小; 似乎存在不可移除的 min-width: min-content

问题

我有一个 缩小到从未宽于其父级,即使它必须截断其显示文本。max-width: 100% 应该可以做到这一点。

预期的结果

我调整大小后希望的页面,其中 <code>select</code> 剪切了其内容

实际结果

为什么我的没有按预期缩小?它似乎有一个不可移除的 min-width: min-content 问题。

解决方法

更新 (2017 年 9 月 25 日)

下面描述的 Firefox bug 已在 Firefox 53 中修复,指向此答案的链接也已从 Bootstrap 文档中移除。

另外,对于 Mozilla 贡献者不得不部分由于此答案而阻止删除对 -moz-document 的支持,我谨表最诚挚的歉意。

修复方案

在 WebKit 和 Firefox 53 中,您只需在 fieldset 上设置 min-width: 0; 即可覆盖 min-content 的默认值。¹

不过,在 fieldset 方面,Firefox 有点奇怪。若要在早期版本中使其正常工作,您必须将 fieldset 的 display 属性更改为以下值之一:

  • table-cell (推荐)
  • table-column
  • table-column-group
  • table-footer-group
  • table-header-group
  • table-row
  • table-row-group

其中,我推荐 table-cell。table-row 和 table-row-group 都阻止您更改宽度,而 table-column 和 table-column-group 阻止您更改高度。

这(在某种程度上 合理地)会破坏 IE 中的渲染效果。由于只有 Gecko 需要这样做,您可以合理地使用 Mozilla 的专有 CSS 扩展之一 @-moz-document 来对其他浏览器隐藏此效果:

@-moz-document url-prefix() {<pre class="brush:php;toolbar:false">fieldset {
    display: table-cell;
}
登录后复制

}

(这是一个 jsFiddle 演示。)

原因

这解决了问题,但如果您和我一样,您的反应可能是……

什么?

它确实有一个原因,但并不好理解。

fieldset 元素的默认呈现很荒唐,基本上无法在 CSS 中指定。想想看:fieldset 的边框在其与 legend 元素重叠的地方消失,但背景仍然可见!没有任何其他元素组合可以重现此效果。

最重要的是,实现充斥着对旧版行为的让步。其中之一是 fieldset 的最小宽度绝不会小于其内容的固有宽度。WebKit 通过在默认样式表中指定来提供一个覆盖此行为的方法,但 Gecko² 更进一步,在渲染引擎中强制执行此行为。

但是,内部表格元素构成了 Gecko 中一种特殊帧类型。计算具有这些显示值设置的元素的尺寸约束在单独的代码路径中,完全绕过了对 fieldset 强制的最小宽度。

再次重申——对于此问题,Firefox 53 已修复错误,因此如果您仅针对较新版本,则不需要此修补程序。

使用 @-moz-document 安全吗?

对于这一个问题,是安全的。@-moz-document 在 Firefox 的所有版本(直到 53,其中此错误已修复)中都按照预期工作。

这不是偶然。部分原因是由于此答案,限制 @-moz-document 为用户/UA 样式表的错误被设置为首先依赖于所修复的底层 fieldset 错误。

除此之外,不要在 CSS 中使用 @-moz-document 将 Firefox 作为目标浏览器,尽管有其他资源也如此。³

以上是为什么我的没有按预期缩小?它似乎有一个不可移除的 min-width: min-content 问题。的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

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

热门文章

<🎜>:泡泡胶模拟器无穷大 - 如何获取和使用皇家钥匙
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆树的耳语 - 如何解锁抓钩
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系统,解释
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1667
14
CakePHP 教程
1426
52
Laravel 教程
1328
25
PHP教程
1273
29
C# 教程
1255
24
静态表单提供商的比较 静态表单提供商的比较 Apr 16, 2025 am 11:20 AM

让我们尝试在这里造成一个术语:“静态表单提供商”。你带上html

使Sass更快的概念证明 使Sass更快的概念证明 Apr 16, 2025 am 10:38 AM

在一个新项目开始时,Sass汇编发生在眼睛的眨眼中。感觉很棒,尤其是当它与browsersync配对时,它重新加载

每周平台新闻:HTML加载属性,主要的ARIA规格以及从iframe转移到Shadow dom 每周平台新闻:HTML加载属性,主要的ARIA规格以及从iframe转移到Shadow dom Apr 17, 2025 am 10:55 AM

在本周的平台新闻综述中,Chrome引入了一个用于加载的新属性,Web开发人员的可访问性规范以及BBC Move

带有HTML对话框元素的一些动手 带有HTML对话框元素的一些动手 Apr 16, 2025 am 11:33 AM

这是我第一次查看HTML元素。我已经意识到了一段时间,但是尚未将其旋转。它很酷,

纸张形式 纸张形式 Apr 16, 2025 am 11:24 AM

购买或建造是技术的经典辩论。自己构建东西可能会感觉更便宜,因为您的信用卡账单上没有订单项,但是

'订阅播客”链接应在哪里? '订阅播客”链接应在哪里? Apr 16, 2025 pm 12:04 PM

有一段时间,iTunes是播客中的大狗,因此,如果您将“订阅播客”链接到喜欢:

托管您自己的非JavaScript分析的选项 托管您自己的非JavaScript分析的选项 Apr 15, 2025 am 11:09 AM

有很多分析平台可帮助您跟踪网站上的访问者和使用数据。也许最著名的是Google Analytics(广泛使用)

它全部都在头上:管理带有React头盔的React Power Site的文档头 它全部都在头上:管理带有React头盔的React Power Site的文档头 Apr 15, 2025 am 11:01 AM

文档负责人可能不是网站上最迷人的部分,但是其中所处的内容对于您的网站的成功也一样重要

See all articles