table td的宽度详解

前言:一直总觉得td的宽度好难驾驭,但万事万物总是有规律的。就像亮剑说的:不用因为怕八路就敬而远之,应该靠上去,熟悉他们,了解他们。

正文:

  • Table只有Table的宽度是可以设置的,并且各个浏览器理解一致

  • 1.原则上应该讲table的宽度设置成一个固定的值,而不应该设置成一个根据屏幕变化的值
    Table的宽度为600px,Table的td所有宽度总和不到600px,浏览器会自动按照td的宽度的比例算出宽度

    <table style="width: 600px;border-collapse: collapse;" >
         <tr>
             <td style="width: 200px;">我是200px</td>
            <td style="width: 200px;">我也是200px</td>
         </tr>
     </table>
    

    运行结果:两个td都是300px;

  • 2.Table的宽度为600px,前两个td的宽度已经为600px,那么第三个td的宽度没有指定,这样的话第三个td的宽度是根据内容出现宽度的,然后前两个再按照比列计算、
    前两个td小于table宽度,那么最后一个td就起到补全的作用

     <table style="width: 600px;border-collapse: collapse;" >
        <tr>
            <td style="width: 300px;">我是200px</td>
            <td style="width: 300px;">我也是200px</td>
            <td >我是根据内容的</td>
        </tr>
    </table>
    
  • 3.Table中的td内,如果放置块状元素超过td的宽度,并且table的table-layout: fixed;(fixed表示td的宽度是定长的,不随td内容变化而变化)。
    这样尽量不要再td里写overflow: auto; 因为这样在IE6,7不会出现滚动条的,最好的办法是套一个div,宽度设置成100%

    <table style="width: 600px;border-collapse: collapse;table-layout: fixed;" >
       <tr>
           <td style="width: 200px;"><div style="width: 100%;overflow: auto;"><div style="width: 300px;height: 100px;background-color: red;"></div></div></td>
          <td >我是自由宽度</td>
       </tr>
    </table>
    

原文参考

猜你喜欢

转载自blog.csdn.net/w1418899532/article/details/84068836