首页 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

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

热工具

记事本++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教程
1664
14
CakePHP 教程
1422
52
Laravel 教程
1316
25
PHP教程
1266
29
C# 教程
1239
24
Google字体可变字体 Google字体可变字体 Apr 09, 2025 am 10:42 AM

我看到Google字体推出了新设计(Tweet)。与上一次大型重新设计相比,这感觉更加迭代。我几乎无法分辨出区别

如何使用HTML,CSS和JavaScript创建动画倒计时计时器 如何使用HTML,CSS和JavaScript创建动画倒计时计时器 Apr 11, 2025 am 11:29 AM

您是否曾经在项目上需要一个倒计时计时器?对于这样的东西,可以自然访问插件,但实际上更多

HTML数据属性指南 HTML数据属性指南 Apr 11, 2025 am 11:50 AM

您想了解的有关HTML,CSS和JavaScript中数据属性的所有信息。

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

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

我们如何创建一个在SVG中生成格子呢模式的静态站点 我们如何创建一个在SVG中生成格子呢模式的静态站点 Apr 09, 2025 am 11:29 AM

格子呢是一块图案布,通常与苏格兰有关,尤其是他们时尚的苏格兰语。在Tar​​tanify.com上,我们收集了5,000多个格子呢

如何在WordPress主题中构建VUE组件 如何在WordPress主题中构建VUE组件 Apr 11, 2025 am 11:03 AM

内联式模板指令使我们能够将丰富的VUE组件构建为对现有WordPress标记的逐步增强。

php是A-OK用于模板 php是A-OK用于模板 Apr 11, 2025 am 11:04 AM

PHP模板通常会因促进Subpar代码而变得不良说唱,但这并不是这样的情况。让我们看一下PHP项目如何执行基本的

静态表单提供商的比较 静态表单提供商的比较 Apr 16, 2025 am 11:20 AM

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

See all articles