table笔记:一行里所有td的rowspan都大于1时,表格格式乱套问题及解决。

前端 专栏收录该内容
11 篇文章 0 订阅

问题:

table里用rowspan合并单元格,整个表格崩掉:

HTML:

<table style="margin:auto;width:100%;table-layout:fixed" border="1" cellspacing="0" cellpadding="0">
        <tbody>
            <tr>
                <td height="80" rowspan="4" colspan="3"><p>xxxxxx</p></td>
                <td height="20" rowspan="1" colspan="3"><p>xxx</p></td>
                <td height="20" rowspan="1" colspan="2"><p>colspan="2"</p></td>
                <td height="20" rowspan="1" colspan="3"><p>xxxx</p></td>
                <td height="20" rowspan="1" colspan="3"><p>colspan="3"</p></td>
                <td height="20" rowspan="1" colspan="3"><p>xxx</p></td>
                <td height="20" rowspan="1" colspan="3"><p>colspan="3"</p></td>
            </tr>
            <tr>
                <td height="20" rowspan="1" colspan="3"><p>xxx</p></td>
                <td height="20" rowspan="1" colspan="2"><p>colspan="2"</p></td>
                <td height="20" rowspan="1" colspan="3"><p>xxxx</p></td>
                <td height="20" rowspan="1" colspan="9"><p>colspan="9"</p></td>
            </tr>
            <tr>
                <td height="40" rowspan="2" colspan="3"><p>xxx</p></td>
                <td height="40" rowspan="2" colspan="2"><p>colspan="2"</p></td>
                <td height="40" rowspan="2" colspan="3"><p>xx</p></td>
                <td height="40" rowspan="2" colspan="9"><p>colspan="9"</p></td>
            </tr>
            <tr>
                <td height="80" rowspan="4" colspan="3"><p>xx</p></td>
                <td height="20" rowspan="3" colspan="3"><p>xxxx</p></td>
                <td height="20" rowspan="1" colspan="2"><p>xxx</p></td>
                <td height="20" rowspan="3" colspan="3"><p>xxx</p></td>
                <td height="20" rowspan="3" colspan="3"><p>xxxxxxxx</p></td>
                <td height="20" rowspan="1" colspan="3"><p>xxxxxxxxx</p></td>
                <td height="20" rowspan="1" colspan="3"><p>xxxx</p></td>
                <td height="20" rowspan="3" colspan="2"><p>xxxxxxxx</p></td>
            </tr>
            <tr>
                <td height="40" rowspan="2" colspan="1"><p>xx</p></td>
                <td height="40" rowspan="2" colspan="1"><p>xxxx</p></td>
                <td height="40" rowspan="2" colspan="2"><p>x</p></td>
                <td height="40" rowspan="2" colspan="1"><p>xxx</p></td>
            </tr>
            <tr>
                <td height="20" rowspan="1" colspan="3"><p>1</p></td>
                <td height="20" rowspan="1" colspan="1"><p>1</p></td>
                <td height="20" rowspan="1" colspan="1"><p>1</p></td>
                <td height="20" rowspan="1" colspan="3"><p>1</p></td>
                <td height="20" rowspan="1" colspan="3"><p>1</p></td>
                <td height="20" rowspan="1" colspan="1"><p>1</p></td>
                <td height="20" rowspan="1" colspan="3"><p>1</p></td>
                <td height="20" rowspan="1" colspan="1"><p>1</p></td>
                <td height="20" rowspan="1" colspan="3"><p>1</p></td>
            </tr>
        </tbody>
    </table>

 

原因(参考链接)、解决:

因为rowspan是用来占行的,如果一行里全部td的 rows 都为2
则意味着 下一tr 里应该是没有 td 元素的
但是实际上 下一tr 又有td,所以这行的td没有容身之处,被挤到右边去了

既然是占没有td的tr行,就给一个空的tr:

如图:

  • 0
    点赞
  • 0
    评论
  • 0
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

©️2021 CSDN 皮肤主题: 大白 设计师:CSDN官方博客 返回首页
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值