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>
    

原文参考

  • 3
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值