html – TABLE比包含DIV更宽

在下面的示例中,也可以使用 here,WebKit(Safari 5,Chrome 10.0.648.205)和Mozilla(FF 4)都保持DIV div围绕浏览器窗口的可见宽度,而TABLE与其内容一样宽。

我希望DIV可以像TABLE一样广泛,但是由于浏览器的行为是一致的,我怀疑这是一个功能而不是一个bug。

有趣的是,如果DIV设置为float:left,it does grow as wide as the table

任何解释?

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN">
<html>
<head>
<title>Wide Table</title>
<style>

#container {
    background-color:blue;
/*    float:left;*/
}

</style>
</head>
<body>
  <div id="container">
    <table >
       <tr id="tr">
         <td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td><td>Table&nbsp;Cell</td>
       </tr>
    </table>
  </div>
</body>
</html>

解决方法

默认情况下,块元素取其父元素的宽度,而不是其内容的宽度;另一方面,高度是相反的工作方式:块元素默认的高度内容,而不是父母的高度。事情以这种方式工作,因为HTML / CSS是围绕英文文本的通常的从上到下的布局构建的。

所以,#container的宽度为< body>然后< table> #container内部的#container外部溢出。如果你把溢出:隐藏在#container上,你将剪辑< table>,overflow-x:auto; #container上会添加一个滚动条。

更新:就浮动元素而言,CSS3 spec有这样的说法:

The used value of ‘width’ is the computed value,unless that is ‘auto’,when used value is the shrink-to-fit width.

默认宽度为auto,因此shrink-to-fit是:

Calculation of the shrink-to-fit width is similar to calculating the width of a table cell using the automatic table layout algorithm. Roughly: calculate the preferred width by formatting the content without breaking lines other than where explicit line breaks occur,and also calculate the preferred minimum width,e.g.,by trying all possible line breaks.

您的< table>中没有任何换行符所以浮动的#container将占据其< table>的整个宽度。儿童。

相关文章

操作步骤 1、进入elasticsearch的plugin,进入ik。进入config。 2、在config下面建立以.dic为后缀的字典...
lengend data数据中若存在&#39;&#39;,则表示换行,用&#39;&#39;切割。
代码实现 option = { backgroundColor: &amp;#39;#080b30&amp;#39;, tooltip: { trigger: &...
问题原因 原因在于直接在js中取的变量并复制给var变量。 于是就变成这样。 解决办法 var data = &#...
前言 最近做了一个调查问卷导出的功能,需求是将维护的题目,答案,导出成word,参考了几种方案之后,选...
对于很多人来说,用字符编码都是熟能生巧,而不清楚为什么是那样的字符编码,所以我在这列了一个表,翻...