- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
这个问题出自this existing question我提供了解决方案,但无法解释原因。
我已经将他们的 fiddle 精简到只剩骨架,并具有以下 HTML/CSS:
<div class="table">
<span class="cell-1">cell 1</span>
<span class="cell-2">cell 2</span>
</div>
.table {
display: table;
}
.cell-1, .cell-2 {
display: table-cell;
padding: 6px 12px;
border: 1px solid #ccc;
}
.cell-1 {
padding: 6px 12px;
background-color: #eee;
border-right: 0;
border-radius: 4px 0 0 4px;
width: 1%; /* *** FOCUS HERE *** */
}
.cell-2 {
border-radius: 0 4px 4px 0;
}
只有 .cell-1
有宽度,即 1%。 <强> This is the result (fiddle link) :
如果我随后将 .cell-1
的宽度增加到比其内容更宽的值,比如 10%(我认为这就是模式),那么第二个单元格将变得更窄。为什么?这个宽度从何而来?<强> This is the result (fiddle link).
如果我接着使用第二个示例,但将 width: 100%
添加到 .table
中,它会再次回到 100%。 <强> Here's the result of that (fiddle link) .
我确信有一个合乎逻辑的解释,但我只是没有看到。有人吗?
最佳答案
这是浏览器实现的自动表格布局算法的结果。这可能因浏览器而异,因为 the CSS2.1 spec doesn't specify all auto layout behavior , 但它确实概述了浏览器通常使用 HTML 表格的算法,因为 CSS 表格模型大部分基于 HTML 表格模型。
通常,如果表格没有指定宽度(即它使用默认的 auto
),那么具有百分比宽度的单元格与其内容所要求的一样宽,并且没有更多的。然后将计算出的宽度(与其他单元格上指定的任何其他宽度一起)用作找到整个表格的最大宽度的百分比,其余列将相应地调整大小。请注意,该表仍可能受其包含 block 的约束(在您的示例中,它是由结果 Pane 建立的初始包含 block )。
在我运行 Firefox 的 PC 上,.cell-1
的计算宽度为 33 像素。当您将其宽度指定为 1% 时,表格的最大宽度为 3300 像素 (33 × 100 = 3300)。你需要一个非常大的屏幕才能在你的例子中看到这个,所以 I removed the padding which drastically reduces the width of .cell-1
to 9 pixels and thus the maximum table width to 900 pixels .如果将预览 Pane 的大小调整为大于 900 像素,您将看到表格在此时停止增长。
当您将 .cell-1
的宽度增加到 10% 时,同样的 33 个像素现在变为表格最大宽度的 10%。反过来,最大表格宽度变为 330 像素(实际上是 3300 像素的 10%,因为 100 ÷ 10 = 10)。
当您将 .table
的宽度指定为 100% 时,表格会根据其包含 block 调整大小。在您的情况下,这仅意味着将其拉伸(stretch)到结果 Pane 的整个宽度。 .cell-1
仍然必须遵守其 width: 10%
声明,因此它延伸到表格宽度的 10%,因为内容不需要任何更宽的东西.如果将结果 Pane 的大小调整为非常窄的宽度,您会看到 .cell-1
与表格一起缩小,但不会超过其最小内容宽度。
关于html - `display: table-cell` 宽度是如何计算的?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21130221/
cell.layoutIfNeeded() 和 cell.layoutSubviews() 和 cell.setNeedsDisplay() 方法一般有什么作用? 最佳答案 布局 subview 布置
是否可以在GXT 3.0中逐个单元地定义编辑器类型? 我需要创建一个转置表;列变成行,行变成列。在这种情况下,一列(从普通表格的角度来看)将具有不同的编辑器类型,而一行将具有相同的编辑器类型。 我正在
我的表格 View 中前 3 个单元格有一个标签,上面写着“松鼠”这个词。有没有办法做到这一点,如果 UILabel 在我的表格中的多个单元格中显示“Squirrels”,则只显示三个单元格中的第一个
让键和值相同有什么意义? JVM 会优化内存并使它们在堆中仅一份吗? 最佳答案 Map通常用于实现Set具有与背景图相同的属性。例如。如果映射是线程安全的,则相应的集合也将是线程安全的。如果 map
这个问题在这里已经有了答案: Testing for nil in Objective-C -- if(x != nil) vs if(x) (4 个答案) 已关闭 9 年前。
我用谷歌表格记录我们俱乐部的出席率。该表格链接到另一个谷歌表格,因此可以自动创建一个名字列表,并按字母顺序排序。在这张表格中,我还根据我们所做的活动,在人的名字旁边手动输入点数。。问题是,由于姓名列表
下面的代码如何工作: .Range("D4:F4").copy .cells(1,1).PasteSpecial 虽然下面不起作用: .Range("D4:F4").copy .cells(1,1)
我正在将一些值传递到 MySQL 数据库表中,我在考虑将整个 javascript 对象数组作为字符串传递是否更快,或者我是否应该根据速度将它们拆分为单元格。 例子: JavaScript 数组: v
display: table-cell; 和单元格之间的空间有问题。我希望所有单元格具有动态相同的宽度。 参见 JSFiddle "Ausstattung & Skizze" 比其他的要宽得多。有没有
我正在使用 apache poi 3.11,从 CellReference,我可以使用以下代码获取 rowIndex 和 Column Index。 CellReference cr = new Ce
我有一个带有圆形和阴影掉落单元格的 Collection View 。当单元格即将被导航栏覆盖时,单元格的阴影突然消失,而不是平滑地移出 View 。下面是代码: contentView.la
我刚开始使用 Swift 作为编程语言,但我遇到了自定义单元格的问题。 当我尝试创建自定义单元格,然后继续尝试按照我需要的方式设计它们(样式设置为自定义)时,一切看起来都不错。现在我不知道如何将特定数
目前,如果满足某些条件,我正在尝试设置一系列单元格的样式。我能够成功地将样式应用于一个单元格,但迄今为止未能成功地将其应用于一个范围。这是我所知道的有效方法: ElseIf OneA / OneC >
如果单元格 A1 为空白并且同一行中的任何单元格不为空白,我需要突出显示它。该行中的大多数单元格中都会包含公式。 最佳答案 创建一个新的条件格式,并使用这个公式: =AND($A$1="",COUNT
我确定这一定是可能的,但我找不到这样做的方法。 我有 2 列,一列带有数字,第二列带有日期。 例如: 数字日期 1 7月21日 2 7 月 22 日 3 7 月 23 日 4 7 月 24 日 5 7
我可能对范围有点困惑(我读过很多关于它的教程,但此时我不明白如何制作这个东西),无论如何,这就是我想要做的: 我有一个包含各种单元格的表格 Bla 1
宏记录器生成以下语句: Cells.Select 现在我明白,如果没有对象限定符,这会将所有单元格作为 Range 对象返回。 但是,我想知道这个语句的完全限定版本是什么? 是吗: Applicati
我知道 Range() 和 Cells() 属性是访问工作表上单元格的等效方法。但是,什么时候在这种组合中使用 Range.Cells() 是明智的呢? 我遇到了一个使用 Range("A1").Re
我有一个动态表,其中每一行都有一个文本框 (txtCantitate) 和一个按钮 (btnMinus)。在文本框中我有数量 (int) 并在按钮上单击我希望数量减少一个。在这里你有我在 table
我有两个 viewController。第一个 VC 在 tableCell 内有 collectionCell。第二个 VC 有 collectionCell,我有 swift File 和 Mod
我是一名优秀的程序员,十分优秀!